我在使用 PHP 数据对象函数时遇到了一些严重问题。我正在尝试使用缓冲查询遍历一个相当大的结果集(~60k 行,~1gig)以避免获取整个结果集。
无论我做什么,脚本都挂在 PDO::query() 上 - 似乎查询正在无缓冲运行(为什么结果集大小的变化会“解决”问题?)。这是我重现问题的代码:
<?php
$Database = new PDO(
'mysql:host=localhost;port=3306;dbname=mydatabase',
'root',
'',
array(
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
PDO::MYSQL_ATTR_USE_BUFFERED_QUERY => true
)
);
$rQuery = $Database->query('SELECT id FROM mytable');
// This is never reached because the result set is too large
echo 'Made it through.';
foreach($rQuery as $aRow) {
print_r($aRow);
}
?>
如果我用一些合理的数量限制查询,它工作正常:
$rQuery = $Database->query('SELECT id FROM mytable LIMIT 10');
我尝试过使用 PDO::MYSQL_ATTR_MAX_BUFFER_SIZE 并使用 PDO::prepare() 和 PDO::execute() (尽管上述查询中没有参数),但都无济于事。任何帮助,将不胜感激。