PHP PDO缓冲查询问题
发布时间:2020-05-25 09:24:43 所属栏目:PHP 来源:互联网
导读:我在使用 PHP数据对象函数时遇到了一些严重的问题.我正在尝试使用缓冲查询循环一个相当大的结果集(~60k行,~1gig)以避免获取整个集合. 无论我做什么,脚本只是挂在PDO :: query()上 – 似乎查询运行无缓冲(为什么结果集大小的变化’修复’问题呢?).这是我重现
|
我在使用 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()(虽然上面的查询中没有参数),两者都无济于事.任何帮助,将不胜感激. 如果我理解这一点,缓冲查询涉及告诉PHP您希望在开始处理之前等待整个结果集.在PDO之前,这是默认设置,如果您想立即处理结果,则必须调用mysql_unbuffered_query.
为什么在PDO MySQL驱动程序页面上没有解释这个,我不知道. (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
