首页 >后端开发 >php教程 >如何使用 mysqli_multi_query() 修复'严格标准:mysqli_next_result() 错误”?

如何使用 mysqli_multi_query() 修复'严格标准:mysqli_next_result() 错误”?

DDD
DDD原创
2024-11-29 05:39:171032浏览

How to Fix

严格标准:mysqli_next_result() mysqli_multi_query 错误

问题:

使用 mysqli_multi_query( )触发一个与 mysqli_next_result() 相关的“严格标准”错误。

解决方案:

要解决此问题,请使用以下代码:

do{} while(mysqli_more_results($db) && mysqli_next_result($db));

说明:

发生严格标准错误是因为必须调用 mysqli_more_results() 来检查是否应使用 mysqli_next_result()。提供的代码片段确保仅在存在另一个结果集时才调用 mysqli_next_result()。

注意事项:

  • 在提供的示例中,仅 INSERT 查询正在执行,不返回结果集。因此,循环不会执行,错误也不会发生。
  • 如果您的查询包含 SELECT 语句或其他返回结果集的操作,提供的解决方案将防止出现错误消息。
  • 修改后的代码片段使用了do-while循环,这是后测试的,不需要在循环内有条件中断或退出

增强功能:

要获得更强大的方法,请考虑以下代码片段:

if(mysqli_multi_query($db,$querystring)){
    do{
        $cumulative_rows+=mysqli_affected_rows($db);
    } while(mysqli_more_results($db) && mysqli_next_result($db));
}
if($error_mess=mysqli_error($db)){echo "Error: $error_mess";}
echo "Cumulative Affected Rows: $cumulative_rows";

此代码片段:

  • 计算 INSERT、UPDATE 或删除查询。
  • 显示累积受影响的行。
  • 检查错误并提供信息性错误消息。

附加说明:

对于不熟悉 mysqli_multi_query() 的用户,这里有一个通用代码处理带或不带结果集的查询的代码片段:

while((isset($multi_query) && (next($queries) && mysqli_more_results($mysqli) && mysqli_next_result($mysqli))) || (!isset($multi_query) && $multi_query=mysqli_multi_query($mysqli,implode(';',$queries)))){
    echo "<br><br>",key($queries),": ",current($queries);  // display array pointer key:value
    if($result=mysqli_store_result($mysqli)){
        while($rows=mysqli_fetch_assoc($result)){
            echo "<br>Col = {$rows["Col"]}";
        }
        mysqli_free_result($result);
    }
    echo "<br>Rows = ",mysqli_affected_rows($mysqli); // acts like num_rows on SELECTs
}

此代码片段:

  • 适用于所有类型的查询,包括 SELECT、INSERT、UPDATE 和 DELETE。
  • 提供详细的输出,包括查询本身、受影响的行或列值以及潜在的错误。
  • 可以根据特定需求或数据库结构轻松修改。

以上是如何使用 mysqli_multi_query() 修复'严格标准:mysqli_next_result() 错误”?的详细内容。更多信息请关注PHP中文网其他相关文章!

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