4
$data=$stmt->fetchAll(); //Dumping the data shows the result. It is also setting the cursor at the end

while($data=$stmt->fetch())
{
//Does not enters loop
//If fetchAll() removes it work as usual
}

我知道它不需要两次获取数据。但我的主要问题是如何重置 PDO 中的光标位置?

4

1 回答 1

8

AFAIK 无法使用 PDO 重置游标位置 - 这可能与与某些不支持重置内部游标的数据库的兼容性有关。

如果要对结果进行两次迭代,请将其提取到数组并迭代此数组:

<?php 
$results = $stmt->fetchAll();  
foreach($results as $row) {
    // first
}

foreach($results as $row) {
    // second
}

编辑一些数据库支持可滚动游标。要使用它,请在方法中添加PDO::CURSOR_SCROLL标志prepare(请参阅PDOetch 文档页面中的示例)。但这只会增加向前或向后移动的可能性,而不是完全倒带。此外,并非所有数据库都支持这种类型的游标(例如 MySQL 不支持)。

于 2013-02-27T12:09:52.280 回答