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

DDD
發布: 2024-11-02 08:15:03
原創
490 人瀏覽過

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中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!