首页 >数据库 >mysql教程 >如何解决 MySQL 错误'当其他无缓冲查询处于活动状态时无法执行查询”?

如何解决 MySQL 错误'当其他无缓冲查询处于活动状态时无法执行查询”?

Patricia Arquette
Patricia Arquette原创
2024-12-07 17:03:121012浏览

How to Solve the MySQL Error

解决 MySQL 的“无法在其他无缓冲查询处于活动状态时执行查询”错误

简介:

MySQL 的客户端协议施加了一项限制,即只能同时执行一个查询。当尝试执行其他查询而先前查询的结果仍未获取时,用户可能会遇到错误“在其他未缓冲的查询处于活动状态时无法执行查询”。此问题可能在特定情况下出现,特别是当使用 PHP 数据对象 (PDO) 并将 PDO::ATTR_EMULATE_PREPARES 属性设置为 false 时。

原因:

根本原因在于 MySQL 客户端协议无法同时进行多个查询。执行查询后,客户端库会自动获取所有结果并缓存它们,使后续获取能够迭代存储的结果,而无需与 MySQL 通信。这种方法称为“缓冲查询”,一旦检索到初始结果,MySQL 服务器就可以免于进一步处理。

相反,非缓冲查询不会缓存结果,需要客户端一次获取一个结果。当在第一个查询的结果完全获取之前执行第二个查询时,就会出现此约束。 MySQL 服务器将此解释为活动查询之间的冲突并触发错误消息。

解决方案:

要解决此问题,可以采用以下策略:

  • 使用 fetchAll():通过调用fetchAll() 方法,检索所有查询结果并在 PHP 中缓存。这种方法有效地模拟了缓冲查询,允许后续查询执行而不会遇到错误。
  • 启用 PDO::MYSQL_ATTR_USE_BUFFERED_QUERY:将此 PDO 属性设置为 true 强制使用缓冲查询,无论 PDO::ATTR_EMULATE_PREPARES 设置如何。此方法可确保在第一次获取时隐式获取所有结果,从而防止与后续查询发生冲突。
  • 关闭游标:在查询上调用 closeCursor() 显式通知 MySQL 服务器它的结果可以被丢弃。这允许执行新查询而不会遇到错误。应该注意的是,只有在获取所有预期结果后才应使用 closeCursor()。

其他注意事项:

  • 由于 PHP 版本的变化,与 MySQL 客户端库的兼容性可能会有所不同,该问题可能会间歇性出现。
  • 当存在多个活动查询且每个查询都涉及一个结果集时,最常出现该错误超过一行。
  • 建议切换到 MySQL Native Driver (mysqlnd),因为它提供了更好的功能和内存

代码示例:

可以修改提供的代码以通过利用 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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn