【发布时间】:2013-10-07 01:38:39
【问题描述】:
循环代码中的经典事务:
$mysqli->query("START TRANSACTION");
foreach ($pdata as $key => $value) {
$sql = "INSERT INTO temp (`fund_id`) VALUES (" . $value . ")";
$result = $mysqli->query($sql);
}
$mysqli->query("COMMIT");
然后我们改为prepared statements:
$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) 是否需要为prepared statements 块添加$mysqli->query("START TRANSACTION");,否则当我们设置autocommit(FALSE) 时事务会自动启动?
【问题讨论】:
-
关闭自动提交后,您不需要
START TRANSACTION。你可以$mysqli->prepare()before 你的循环,然后在foreach循环内执行()它。每次循环迭代都不需要prepare()。 -
您也不需要每次都
bind_param()。它绑定了对变量的引用,因此每次执行时都会使用变量的当前值。
标签: php mysql transactions mysqli