首页 >数据库 >mysql教程 >如何解决 MySQLi'命令不同步”错误?

如何解决 MySQLi'命令不同步”错误?

Linda Hamilton
Linda Hamilton原创
2024-12-13 02:34:11356浏览

How to Resolve the MySQLi

MySQLi 中的“命令不同步”错误:全面解释

当新的命令出现时,MySQLi 会抛出“命令不同步”错误在上一个查询中仍有未读行的情况下尝试查询

错误原因

MySQL 客户端协议要求在执行新查询之前获取查询的所有结果。这可以确保处理结果集的一致性并防止数据丢失。

解决方案

mysqli_store_result() 或 mysqli_result::fetch_all():

使用以下命令从外部查询中预取所有行mysqli_store_result() 或使用 mysqli_result::fetch_all() 以数组形式获取整个结果集。这会在客户端缓冲结果,从而允许执行多个查询。

存储过程和 mysqli_multi_query():

存储过程可以返回多个结果集。要处理此问题,请使用 mysqli_multi_query() 并使用 mysqli_next_result() 迭代结果,直到处理完所有结果集。

代码片段

这是以下的修改版本问题中的代码,使用mysqli_store_result():

$result = mysqli_query($db, $sql) or exit(mysqli_error($db));

if ($result) {
    $result->store_result(); // Buffer the result set
    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));

        if ($result = mysqli_fetch_assoc($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);

可能的设计改进

在关系数据库中存储分层数据可能会导致复杂的查询。考虑使用替代模型,例如嵌套集或邻接列表,来简化数据存储和检索。

以上是如何解决 MySQLi'命令不同步”错误?的详细内容。更多信息请关注PHP中文网其他相关文章!

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