php – 为什么mysqli给出“命令不同步”错误?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了php – 为什么mysqli给出“命令不同步”错误?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3017字,纯文字阅读大概需要5分钟。
内容图文
![php – 为什么mysqli给出“命令不同步”错误?](/upload/InfoBanner/zyjiaocheng/891/292bb8630c5f4bf8b6be1723f5a17413.jpg)
我正在尝试运行以下内容.
<?php
$db = mysqli_connect("localhost","user","pw") or die("Database error");
mysqli_select_db($db, "database");
$agtid = $_POST['level'];
$sql = sprintf("call agent_hier(%d)", $agtid);
$result = mysqli_query($db, $sql) or exit(mysqli_error($db));
if ($result) {
echo "<table border='1'>
<tr><th>id</th>
<th>name</th>
<th>parent_id</th>
<th>parent_name</th>
<th>level</th>
<th>email</th></tr>";
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("<tr><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td></tr>",
$row["id"],$row["name"],
$row["parent_id"],$row["parent_name"],
$row["level"],$row["email"]);
}
echo "</table>";
}
mysqli_free_result($result);
mysqli_close($db);
?>
如果我删除以下行:
$aid = $row["agent_id"];
至….
$date = abs(strtotime(date('m/d/Y')) - strtotime(date($kdate))) / (60 * 60 * 24);
}
一切都会好起来的.如果没有,我收到以下错误:
Commands out of sync; you can’t run this command now
在研究中,我认为这可能是由于多个MySQLi查询同时运行,其中使用mysqli_multi_query但是对于the guide中的所有样本和一般数据似乎都不适用.
有任何想法吗?
解决方法:
MySQL客户端不允许您执行新查询,其中仍有从正在进行的查询中提取的行.有关常见错误,请参阅MySQL文档中的Commands out of sync.
您可以使用mysqli_store_result()预取外部查询中的所有行.这将在MySQL客户端中缓冲它们,因此从服务器的角度来看,您的应用程序已获取完整的结果集.然后,即使在从now-buffered外部结果集中获取行的循环中,您也可以执行更多查询.
或者您mysqli_result::fetch_all()将完整结果集作为PHP数组返回,然后您可以循环该数组.
调用存储过程是一种特殊情况,因为存储过程有可能返回多个结果集,每个结果集可能有自己的一组行.这就是@ a1ex07的答案提到使用mysqli_multi_query()并循环直到mysqli_next_result()没有更多结果集的原因.这是满足MySQL协议所必需的,即使在您的情况下您的存储过程只有一个结果集.
PS:顺便说一句,我看到你正在进行嵌套查询,因为你有代表层次结构的数据.您可能需要考虑以不同方式存储数据,以便您可以更轻松地查询它.我做了一个关于这个标题为Models for Hierarchical Data with SQL and PHP的演讲.我还在我的书SQL Antipatterns: Avoiding the Pitfalls of Database Programming的一章中介绍了这个主题.
以下是如何在CodeIgnitor 3.0.3中实现mysqli_next_result():
在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并且不得不将这个hack复制到新版本.
内容总结
以上是互联网集市为您收集整理的php – 为什么mysqli给出“命令不同步”错误?全部内容,希望文章能够帮你解决php – 为什么mysqli给出“命令不同步”错误?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。