PHP Conference Japan 2024

mysqli_result::fetch_all

mysqli_fetch_all

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

mysqli_result::fetch_all -- mysqli_fetch_all将所有结果行作为关联数组、数字数组或两者都获取

描述

面向对象风格

public mysqli_result::fetch_all(int $mode = MYSQLI_NUM): array

过程化风格

mysqli_fetch_all(mysqli_result $result, int $mode = MYSQLI_NUM): array

返回一个二维数组,其中包含所有结果行,作为关联数组、数字数组或两者。

注意:

在 PHP 8.1.0 之前,仅当使用 mysqlnd 时可用。

参数

result

仅过程化风格:由 mysqli_query()mysqli_store_result()mysqli_use_result()mysqli_stmt_get_result() 返回的 mysqli_result 对象。

mode

此可选参数是一个常量,指示应从当前行数据生成哪种类型的数组。此参数的可能值为常量 MYSQLI_ASSOCMYSQLI_NUMMYSQLI_BOTH

返回值

返回一个关联或数字数组的数组,其中包含结果行。

变更日志

版本 描述
8.1.0 现在链接到 libmysqlclient 时也可使用。

示例

示例 #1 mysqli_result::fetch_all() 示例

面向对象风格

<?php

mysqli_report
(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);
$mysqli = new mysqli("localhost", "my_user", "my_password", "world");

$result = $mysqli->query("SELECT Name, CountryCode FROM City ORDER BY ID LIMIT 3");

$rows = $result->fetch_all(MYSQLI_ASSOC);
foreach (
$rows as $row) {
printf("%s (%s)\n", $row["Name"], $row["CountryCode"]);
}

过程化风格

<?php

mysqli_report
(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);
$mysqli = mysqli_connect("localhost", "my_user", "my_password", "world");

$result = mysqli_query($mysqli, "SELECT Name, CountryCode FROM City ORDER BY ID LIMIT 3");

$rows = mysqli_fetch_all($result, MYSQLI_ASSOC);
foreach (
$rows as $row) {
printf("%s (%s)\n", $row["Name"], $row["CountryCode"]);
}

以上示例将输出

Kabul (AFG)
Qandahar (AFG)
Herat (AFG)

参见

添加注释

用户贡献的注释 5 条注释

jcastro at eftec dot cl
9 年前
我测试了使用“fetch all”与“while / fetch array”,并且

fetch-all 使用更少的内存(但不是很多)。

在我的案例(test1 和 test2)中:147008,262848 字节(fetch-all)与 147112,262888 字节(fetch-array & while)。

所以,关于内存,在两种情况下都相同。

但是,关于性能
我的测试使用 fetch-all 耗时:350 毫秒(最坏情况),而使用 fetch-array 耗时 464 毫秒(最坏情况),或者使用 fetch array 和 while 循环大约差 35% 。

因此,对于返回适量信息的普通代码,使用 fetch-all
a) 更简洁(一行代码)
b) 使用更少的内存(大约少 0.01%)
c) 更快。

php 5.6 32 位,windows 8.1 64 位

darek334 at gazeta dot pl
1 年前
注意 fetch_all(MYSQLI_ASSOC) 返回的数组格式
<?php
array(0 => array(......), 1 => array(......) .... ), 即使只有一...
?>
与 fetch_assoc() 不同,后者返回一个结果数组,格式为
<?php
array(......)
?>
mail2magvay at rambler dot ru
5 年前
顺便说一句,这种方法也适用

$services = $mysqli->query("SELECT * FROM table1");

if($services && $services->num_rows>0){
$services->fetch_all(MYSQLI_ASSOC);
}

foreach($services as $service){
echo $service; //正常工作,因为它实现了 Iterator 接口
}

这意味着在这种情况下 $services 是一个有效的数组(或空数组)
m dot amiot at otak-arts dot com
12 年前
如果你真的需要这个函数,你可以扩展 mysqli_result 类,添加类似这样的函数。

<?php
public function fetch_all($resulttype = MYSQLI_NUM)
{
if (
method_exists('mysqli_result', 'fetch_all')) # 与 PHP < 5.3 的兼容性层
$res = parent::fetch_all($resulttype);
else
for (
$res = array(); $tmp = $this->fetch_array($resulttype);) $res[] = $tmp;

return
$res;
}
?>
andrey at php dot net
14 年前
返回值在 5.3.3 中发生了变化 - 在 5.3.0 和 5.3.2(包括)之间,当结果集为空时返回 NULL。5.3.3 及更高版本返回空数组。
此外,mysqli_fetch_all 仅适用于缓冲结果集,这是 mysqli_query 的默认设置。MYSQLI_USE_RESULT 将在 5.3.4 及更高版本中得到支持。
但是,以这种方式使用它来实现非缓冲集没有多大意义。在这种情况下,选择 STORE_RESULT,fetch_all 不会复制数据,而是引用它,因为它已经存储在 mysqlnd 中。
To Top