首頁 >後端開發 >php教程 >如何在同一結果集上多次使用「mysqli_fetch_array()」?

如何在同一結果集上多次使用「mysqli_fetch_array()」?

DDD
DDD原創
2024-11-02 08:15:03556瀏覽

How Can I Use `mysqli_fetch_array()` Multiple Times on the Same Resultset?

多次使用mysqli_fetch_array()

使用PHP 和MySQL 處理資料庫時,您可能會遇到需要多次存取相同查詢結果的情況使用mysqli_fetch_array()函數。但是,嘗試在相同結果集中多次使用 mysqli_fetch_array() 將導致空輸出。

這是因為 mysqli_fetch_array() 提取並推進結果集中的指標。因此,如果您嘗試再次取得相同的結果,將沒有任何資料可供檢索。

要解決此問題,您應該將資料操作與輸出分開。首先,從資料庫中取得所有資料並將其儲存在陣列中:

<code class="php">$db_res = mysqli_query($db_link, $sql);
$data = [];
while ($row = mysqli_fetch_assoc($db_res)) {
    $data[] = $row;
}</code>

注意:從PHP 5.3 開始,您可以使用fetch_all() 取代明確循環:

<code class="php">$db_res = mysqli_query($db_link, $sql);
$data = $db_res->fetch_all(MYSQLI_ASSOC);</code>

將資料儲存在陣列中後,您可以根據需要多次迭代它:

頂行:

<code class="php">foreach ($data as $row) {</code>

以上是如何在同一結果集上多次使用「mysqli_fetch_array()」?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn