从头开始迭代 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中文网其他相关文章!