小编Ste*_*art的帖子

PHP PDO缓冲查询问题

我在使用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);
}
?>
Run Code Online (Sandbox Code Playgroud)

如果我用一些合理的数字限制查询,它可以正常工作:

$rQuery = $Database->query('SELECT id FROM mytable LIMIT 10');
Run Code Online (Sandbox Code Playgroud)

我尝试过使用PDO :: MYSQL_ATTR_MAX_BUFFER_SIZE并使用PDO :: prepare()和PDO :: execute()(虽然上面的查询中没有参数),两者都无济于事.任何帮助,将不胜感激.

php mysql pdo

6
推荐指数
1
解决办法
7036
查看次数

标签 统计

mysql ×1

pdo ×1

php ×1