PHP在循环中准备语句和事务[重复]

Posted

技术标签:

【中文标题】PHP在循环中准备语句和事务[重复]【英文标题】:PHP prepared statements and transactions in a loop [duplicate] 【发布时间】: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()。它绑定了对变量的引用,因此每次执行时都会使用变量的当前值。 【参考方案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 语句。

【讨论】:

短小精悍。 是否需要添加rollback语句以防失败? php.net/manual/en/mysqli.rollback.php 我相信您的代码缺少重新开启自动提交功能。

以上是关于PHP在循环中准备语句和事务[重复]的主要内容,如果未能解决你的问题,请参考以下文章

PHP在准备SQL语句时抛出致命错误[重复]

PHP PDO准备语句给出“无效语法”错误[重复]

来自Web表单问题的PHP准备语句[重复]

无法准备 SQL 语句 [重复]

在准备好的语句中不向列 X 插入值的逻辑 [重复]

php mysqi bind_param 变量数与准备好的语句中的参数数不匹配[重复]