PHP PDO缓冲查询问题

发布时间:2022-04-30 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了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);
}
?>

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

$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驱动程序页面上没有解释这个,我不知道.

脚本宝典总结

以上是脚本宝典为你收集整理的PHP PDO缓冲查询问题全部内容,希望文章能够帮你解决PHP PDO缓冲查询问题所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。