首頁 > 後端開發 > php教程 > 如何多次迭代 PDO 結果集?

如何多次迭代 PDO 結果集?

Mary-Kate Olsen
發布: 2024-10-29 14:56:02
原創
1015 人瀏覽過

How to Iterate Through a PDO Result Set Multiple Times?

從頭開始迭代PDO 結果集

從MySQL SELECT 方法轉換到PDO 方法時,重置數組指標以迭代多次獲得結果集可能具有挑戰性。這是由於這些方法處理陣列指標的方式不同。

在提供的程式碼中,第一個 while 迴圈成功地從第 0 行開始迭代所取得的陣列。然而,第二個 while 迴圈傳回一個空集,因為 PDO 的 fetch() 方法在每次呼叫時都會前進數組指標。

要實現所需的行為,可以將結果儲存在數組中,然後迭代該數組多次。以下是一個範例:

$pdo = new PDO('mysql:host=' . $host . ';dbname='.$database, $username, $password);
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

$stmt = $pdo->prepare('SELECT * FROM mytable WHERE active = 1 ORDER BY name ASC');
$stmt->setFetchMode(PDO::FETCH_ASSOC);
$stmt->execute();

$rows = $stmt->fetchAll();

foreach ($rows as $r) {
    // first run
}

foreach ($rows as $r) {
    // second run
}
登入後複製

透過使用 fetchAll(),結果集中的所有行都儲存在 $rows 陣列中。這允許您多次迭代數組,而無需手動重置數組指標。

以上是如何多次迭代 PDO 結果集?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板