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