首页 >后端开发 >php教程 >如何多次迭代 PDO 结果集?

如何多次迭代 PDO 结果集?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-10-29 14:56:02974浏览

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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn