PHP 命令不同步:解决困境
当使用 PHP 和 MySQLi 从 MySQL 数据库检索数据时,执行多个准备好的语句有时会导致错误,“命令不同步,您无法运行该命令现在。”
原因和解决方案
当连接对象($mysqli)有先前查询的待处理结果时,会发生此错误。要解决这个问题,您需要在每个准备好的语句之后调用 $mysqli 对象上的 next_result() 函数。
考虑这个示例:
$stmt = $mysqli->prepare("SELECT id, username, password, firstname, lastname, salt FROM members WHERE email = ? LIMIT 1"); $stmt->bind_param('s', $loweredEmail); $stmt->execute(); $stmt->store_result(); $stmt->bind_result($user_id, $username, $db_password, $firstname, $lastname, $salt); $stmt->fetch(); $stmt->free_result(); $stmt->close(); while ($mysqli->more_results()) { $mysqli->next_result(); } $stmt1 = $mysqli->prepare("SELECT privileges FROM delegations WHERE id = ? LIMIT 1"); $stmt1->bind_param('s', $user_id); // This is where the error occurs $stmt1->execute();
在此代码中,错误将是执行第二条语句($stmt1)时抛出。要修复此问题,请在执行 $stmt1 之前添加以下行:
$mysqli->next_result();
其他提示
以上是PHP MySQLi'命令不同步”:如何修复错误?的详细内容。更多信息请关注PHP中文网其他相关文章!