在我的一个脚本中,我使用一个mysqli_multi_query进行一些删除操作,然后一个mysqli_multi_query()进行一些插入操作。但我得到以下错误。"命令不同步;你现在不能运行这个命令。"我怎么解决它?下面是我的代码片段:
$resourceDeleteSql = "";
$resourceDeleteSql .= "Delete from acl_mr where group_id = $group_id ;";
$resourceDeleteSql .= "Delete from acl_mpr where group_id = $group_id ;";
$resourceDeleteSql .= "Delete from acl_mpfr where group_id = $group_id ;";
$resourceDeleteSqlResult = mysqli_multi_query($con, $resourceDeleteSql) or die(mysqli_error($con));
if ($resourceDeleteSqlResult) {
$resourceInsertSql = '';
foreach ($resource as $moduleKey => $module) {
if (is_array($module)) {
foreach ($module as $pageKey => $page) {
if (is_array($page)) {
foreach ($page as $field) {
$resourceInsertSql .= "INSERT INTO acl_mpfr (group_id ,field_sys_name ,page_sys_name,module_sys_name) VALUES ( '$group_id', '$field', '$pageKey', '$moduleKey');";
}
} else {
$resourceInsertSql .= "INSERT INTO acl_mpr (`group_id` ,`page_sys_name`,`module_sys_name`) VALUES ( '$group_id','$page', '$moduleKey');";
}
}
} else {
$resourceInsertSql .= "INSERT INTO acl_mr (`group_id` ,`module_sys_name`) VALUES ( '$group_id', '$module');";
}
}
$resourceInsertSqlResult = mysqli_multi_query($con, $resourceInsertSql) or die(mysqli_error($con));
查看此链接:http://dev.mysql.com/doc/refman/5.0/en/commands-out-of-sync.html
如果你得到命令不同步;你现在不能在你的客户端代码中运行这个命令,你调用客户端函数的顺序错了。
例如,如果您正在使用mysql_use_result()
,并在调用mysql_free_result()
之前尝试执行新查询,则可能发生。如果您尝试执行两个返回数据的查询而不调用中间的mysql_use_result()
或mysql_store_result()
,也可能发生这种情况。