一尘不染

PHP PDO缓冲查询问题

mysql

我在使用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()(尽管上面的查询中没有参数),但都无济于事。任何帮助,将不胜感激。


阅读 347

收藏
2020-05-17

共1个答案

一尘不染

如果我理解这一权利,则缓冲查询涉及告诉PHP您要在开始处理之前等待整个结果集。在PDO之前,这是默认设置,mysql_unbuffered_query如果您想立即处理结果,则必须致电。

我不知道为什么PDO MySQL驱动程序页面上没有对此进行解释。

2020-05-17