PHP Conference Japan 2024

mysqli::reap_async_query

mysqli_reap_async_query

(PHP 5 >= 5.3.0, PHP 7, PHP 8)

mysqli::reap_async_query -- mysqli_reap_async_query获取异步查询的结果

描述

面向对象风格

public mysqli::reap_async_query(): mysqli_result|bool

过程式风格

mysqli_reap_async_query(mysqli $mysql): mysqli_result|bool

获取异步查询的结果。

注意:

仅适用于 mysqlnd

参数

mysql

仅过程式风格:由 mysqli_connect()mysqli_init() 返回的 mysqli 对象

返回值

失败时返回 false。对于产生结果集的成功查询,例如 SELECT, SHOW, DESCRIBEEXPLAINmysqli_reap_async_query() 将返回一个 mysqli_result 对象。对于其他成功查询,mysqli_reap_async_query() 将返回 true

错误/异常

如果启用了 mysqli 错误报告 (MYSQLI_REPORT_ERROR) 并且请求的操作失败,则会生成警告。此外,如果模式设置为 MYSQLI_REPORT_STRICT,则会抛出 mysqli_sql_exception

参见

添加注释

用户贡献的注释 1 条注释

5
eric dot caron at gmail dot com
14 年前
请记住,mysqli::reap_async_query 仅在 SELECT 等查询中返回 mysqli_result。对于您可能对 affected_rows 或 insert_id 等内容感兴趣的查询,您不能像 mysqli::poll 中的示例那样依赖 mysqli::reap_async_query 的结果。对于 INSERT/UPDATE/DELETE 查询,可以通过 mysqli::poll 函数中第一个数组的相关键访问与查询对应的数据。

所以,而不是
<?php
foreach ($links as $link) {
if (
$result = $link->reap_async_query()) {
print_r($result->fetch_row());
mysqli_free_result($result);
$processed++;
}
}
?>

数据可以通过以下方式访问
<?php
foreach ($links as $link) {
if (
$result = $link->reap_async_query()) {
//这对 SELECT 有效
if(is_object($result)){
print_r($result->fetch_row());
mysqli_free_result($result);
}
//这对 INSERT/UPDATE/DELETE 有效
else {
print_r($link);
}
$processed++;
}
}
?>
To Top