(PHP 5 >= 5.3.0, PHP 7, PHP 8)
mysqli_result::fetch_all -- mysqli_fetch_all — Fetch all result rows as an associative array, a numeric array, or both
Object-oriented style
$mode = MYSQLI_NUM): arrayProcedural style
Returns a two-dimensional array of all result rows as an associative array, a numeric array, or both.
Note:
Prior to PHP 8.1.0, available only with mysqlnd.
resultProcedural style only: A mysqli_result object returned by mysqli_query(), mysqli_store_result(), mysqli_use_result() or mysqli_stmt_get_result().
mode
       This optional parameter is a constant indicating what type of array
       should be produced from the current row data. The possible values for
       this parameter are the constants MYSQLI_ASSOC,
       MYSQLI_NUM, or MYSQLI_BOTH.
      
Returns an array of associative or numeric arrays holding result rows.
| Version | Description | 
|---|---|
| 8.1.0 | Now also available when linking against libmysqlclient. | 
Example #1 mysqli_result::fetch_all() example
Object-oriented style
<?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"]);
}
Procedural style
<?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"]);
}
The above examples will output:
Kabul (AFG) Qandahar (AFG) Herat (AFG)