首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >为什么mysqli会给出“命令不同步”的错误?

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

Stack Overflow用户
提问于 2010-09-03 07:39:45
回答 4查看 46K关注 0票数 25

我正在尝试运行以下命令。

代码语言:javascript
复制
<?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);

?>

如果我从以下位置删除行:

代码语言:javascript
复制
  $aid = $row["agent_id"];

到……

代码语言:javascript
复制
  $date = abs(strtotime(date('m/d/Y')) - strtotime(date($kdate))) / (60 * 60 * 24);
  }

一切都会好起来的。如果不是,我会得到以下错误:

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

在研究中,我认为这可能是由于同时运行多个MySQLi查询,其中使用mysqli_multi_query,但对于the guide中的所有样本和一般数据似乎并不适用。

有什么想法吗?

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2010-09-03 08:48:48

如果仍有行要从正在进行的查询中提取,则MySQL客户端不允许执行新查询。有关常见错误,请参阅MySQL文档中的Commands out of sync

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

或者使用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 change的第262行

代码语言:javascript
复制
protected function _execute($sql)
{
    return $this->conn_id->query($this->_prep_query($sql));
}

到这个

代码语言:javascript
复制
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复制到新版本中。

票数 40
EN

Stack Overflow用户

发布于 2011-07-26 16:13:10

简单地说,您必须在调用mysqli_free_result之后调用mysqli_next_result($db)。

mysqli_next_result($db) mysqli_free_result($result);$result mysqli_close($db);

票数 3
EN

Stack Overflow用户

发布于 2014-09-18 16:26:13

只需调用此函数:

代码语言:javascript
复制
$this->free_result();

function free_result() {
        while (mysqli_more_results($this->conn) && mysqli_next_result($this->conn)) {

            $dummyResult = mysqli_use_result($this->conn);

            if ($dummyResult instanceof mysqli_result) {
                mysqli_free_result($this->conn);
            }
        }
    }
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3632075

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档