解决 MySQL 的“无法在其他无缓冲查询处于活动状态时执行查询”错误
简介:
MySQL 的客户端协议施加了一项限制,即只能同时执行一个查询。当尝试执行其他查询而先前查询的结果仍未获取时,用户可能会遇到错误“在其他未缓冲的查询处于活动状态时无法执行查询”。此问题可能在特定情况下出现,特别是当使用 PHP 数据对象 (PDO) 并将 PDO::ATTR_EMULATE_PREPARES 属性设置为 false 时。
原因:
根本原因在于 MySQL 客户端协议无法同时进行多个查询。执行查询后,客户端库会自动获取所有结果并缓存它们,使后续获取能够迭代存储的结果,而无需与 MySQL 通信。这种方法称为“缓冲查询”,一旦检索到初始结果,MySQL 服务器就可以免于进一步处理。
相反,非缓冲查询不会缓存结果,需要客户端一次获取一个结果。当在第一个查询的结果完全获取之前执行第二个查询时,就会出现此约束。 MySQL 服务器将此解释为活动查询之间的冲突并触发错误消息。
解决方案:
要解决此问题,可以采用以下策略:
其他注意事项:
代码示例:
可以修改提供的代码以通过利用 fetchAll() 或显式设置 PDO::MYSQL_ATTR_USE_BUFFERED_QUERY 为 true 来防止错误.
$sql ='SELECT temp_id FROM temp1'; $stmt2 = db::db()->prepare($sql); $stmt2->execute(); $rs2 = $stmt2->fetchAll(PDO::FETCH_ASSOC); $stmt2->closeCursor(); $sql='SELECT COUNT(*) AS valid FROM cities_has_zipcodes WHERE cities_id=:cities_id AND zipcodes_id=:zipcodes_id'; $stmt1 = db::db()->prepare($sql); foreach($data AS $row) { try { $stmt1->execute($row); $rs1 = $stmt1->fetchAll(PDO::FETCH_ASSOC); $stmt1->closeCursor(); syslog(LOG_INFO,'$rs1: '.print_r($rs1[0],1).' '.rand()); syslog(LOG_INFO,'$rs2: '.print_r($rs2[0],1).' '.rand()); } catch(PDOException $e){echo(sql_error($e));} }
以上是如何解决 MySQL 错误'当其他无缓冲查询处于活动状态时无法执行查询”?的详细内容。更多信息请关注PHP中文网其他相关文章!