從頭開始迭代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中文網其他相關文章!