mysqli为什么会给出“命令不同步”错误?-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文

mysqli为什么会给出“命令不同步”错误?

保持可爱mmm 2020-05-10 22:31:51 45

我正在尝试运行以下内容。

id name parent_id parent_name level email"; while ($row = mysqli_fetch_assoc($result)) { $aid = $row["id"]; $sql2 = "SELECT * FROM members WHERE MEMNO = '$aid'"; $result2 = mysqli_query($db,$sql2) or exit(mysqli_error($db)); while ($newArray = mysqli_fetch_array($result2)) { $fname = $newArray['FNAME']; $lname = $newArray['LNAME']; $mi = $newArray['MI']; $address = $newArray['ADDRESS']; $city = $newArray['CITY']; $state = $newArray['STATE']; $zip = $newArray['ZIP']; $kdate = $newArray['KDATE']; $date = abs(strtotime(date('m/d/Y')) - strtotime(date($kdate))) / (60 * 60 * 24); } echo sprintf("%s%s%s%s%s%s", $row["id"],$row["name"], $row["parent_id"],$row["parent_name"], $row["level"],$row["email"]); } echo ""; } mysqli_free_result($result); mysqli_close($db); ?> 如果我删除以下行:

$aid = $row["agent_id"]; 至....

$date = abs(strtotime(date('m/d/Y')) - strtotime(date($kdate))) / (60 * 60 * 24); } 一切都会正常。如果没有,我得到以下错误:

命令不同步;您现在不能运行此命令

在研究,我认为这可能是由于多个库MySQLi查询同时运行,其中使用mysqli_multi_query但在所有样品和通用数据导向似乎并不适用。

有任何想法吗?

分享到
取消 提交回答
全部回答(1)
  • 保持可爱mmm
    2020-05-11 12:00:22

    MySQL客户端不允许您执行新的查询,在该查询中仍需要从正在进行的查询中获取行。有关常见错误,请参见MySQL文档中的命令不同步。

    您可以用来mysqli_store_result()从外部查询中预提取所有行。这会将它们缓冲在MySQL客户端中,因此从服务器的角度来看,您的应用已获取了完整的结果集。然后,即使在从现在缓冲的外部结果集中提取行的循环中,您也可以执行更多查询。

    或者,您mysqli_result::fetch_all()将完整的结果集作为PHP数组返回,然后可以在该数组上循环。

    调用存储过程是一种特殊情况,因为存储过程有可能返回多个结果集,每个结果集可能都有自己的行集。这就是为什么@ a1ex07的答案提到使用mysqli_multi_query()和循环直到mysqli_next_result()没有更多结果集。即使您的存储过程只有一个结果集,这也必须满足MySQL协议。

    PS:顺便说一句,我看到您正在执行嵌套查询,因为您有代表层次结构的数据。您可能要考虑以不同的方式存储数据,以便可以更轻松地查询它。我做了一个名为“ SQL和PHP的分层数据模型”的演讲。我还在《SQL反模式:避免数据库编程的陷阱》一章中介绍了该主题。

    这是mysqli_next_result()在CodeIgnitor 3.0.3中实现的方法:

    在system/database/drivers/mysqli/mysqli_driver.php变化的第262行

    protected function _execute($sql) { return $this->conn_id->query($this->_prep_query($sql)); } 对此

    protected function _execute($sql) { $results = $this->conn_id->query($this->_prep_query($sql)); @mysqli_next_result($this->conn_id); // Fix 'command out of sync' error return $results; } 从2.x开始,这一直是一个问题。我刚刚更新到3.x,并且不得不将此破解复制到新版本中。来源:stack overflow

    0 0
云计算
使用钉钉扫一扫加入圈子
+ 订阅

时时分享云计算技术内容,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。

推荐文章