PHP在循环中准备语句和事务

时间:2013-10-01 02:23:40

标签: php mysql transactions mysqli

循环代码中的经典事务:

$mysqli->query("START TRANSACTION");
foreach ($pdata as $key => $value) {
    $sql    = "INSERT INTO temp (`fund_id`) VALUES (" . $value . ")";
    $result = $mysqli->query($sql);
}
$mysqli->query("COMMIT");

然后我们改为准备好的陈述:

$mysqli->autocommit(FALSE);
foreach ($pdata as $key => $value) {
    $sql  = "INSERT INTO temp (`fund_id`) VALUES (?)";
    $stmt = $mysqli->prepare($sql);
    $stmt->bind_param('i', $value);
    $stmt->execute();
}
$mysqli->commit();

问题:

1)这两个代码是否相同?我是否在准备好的陈述中遗漏了第二段代码中的内容?

2)$mysqli->commit()$mysqli->query("COMMIT")相同吗?

3)我是否需要为预备语句块添加$mysqli->query("START TRANSACTION");,否则当我们设置autocommit(FALSE)时,事务会自动启动?

1 个答案:

答案 0 :(得分:30)

可以通过将preparebind_param语句拉出循环来优化您的循环。

$value = null;
$mysqli->autocommit(FALSE);
$sql  = "INSERT INTO temp (`fund_id`) VALUES (?)";
$stmt = $mysqli->prepare($sql);
$stmt->bind_param('i', $value);
foreach ($pdata as $value) {
    $stmt->execute();
}
$mysqli->commit();

您已使用autocommit(FALSE)行关闭了自动提交,因此无需使用START TRANSACTION声明。