use*_*490 16 php mysql mysqli transactions
循环代码中的经典事务:
$mysqli->query("START TRANSACTION");
foreach ($pdata as $key => $value) {
$sql = "INSERT INTO temp (`fund_id`) VALUES (" . $value . ")";
$result = $mysqli->query($sql);
}
$mysqli->query("COMMIT");
Run Code Online (Sandbox Code Playgroud)
然后我们改为准备好的陈述:
$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();
Run Code Online (Sandbox Code Playgroud)
问题:
1)这两个代码是否相同?我是否在准备好的陈述中遗漏了第二个代码中的内容?
2)是$mysqli->commit()一样的$mysqli->query("COMMIT")吗?
3)我是否需要$mysqli->query("START TRANSACTION");为准备好的语句块添加或者当我们设置时事务会自动启动autocommit(FALSE)?
And*_*ndy 30
可以通过从循环中拉出prepare和bind_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();
Run Code Online (Sandbox Code Playgroud)
您已使用您的autocommit(FALSE)线路关闭自动提交,因此不需要使用该START TRANSACTION语句.
| 归档时间: |
|
| 查看次数: |
11333 次 |
| 最近记录: |