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

如何多次迭代 PDO 结果集?

Mary-Kate Olsen
发布: 2024-10-29 14:56:02
原创
992 人浏览过

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
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板