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

2022-08-30 23:10:38

循环代码中的经典事务:

$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

可以通过将 和 语句从循环中拉出来优化循环。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


答案 2

推荐