【发布时间】:2012-07-03 23:02:42
【问题描述】:
我有一个长时间运行的查询,我尝试通过无缓冲的 pdo 语句获取它(请参阅下一个代码)。 但是当我“执行”无缓冲查询,或者我执行“fetchAll”时,时间(另见下文)并没有真正改变太多...... 我认为 unbuffered 只是执行查询并给我一个光标?
get_db 函数返回一个 Zend_Db 对象。
l('Start 1');
$sql = get_db('ATO')->select()
... Big query...
->assemble();
l('Assembled');
get_db('APNS')->query($sql)->fetchAll();
l('All fetched... Going again!');
$PDOStatement = get_db('ATO')->getConnection()
->prepare($sql,
array(PDO::MYSQL_ATTR_USE_BUFFERED_QUERY => false));
l('prepared');
if ( $PDOStatement->execute() === false ) {
l(':(');
exit(1);
}
l('fetching');
while ( ($PDOrow = $PDOStatement->fetch()) !== false ) {
}
l ('all done');
function l($t) {
static $start = null;
if ( $start === null ) {
$start = microtime(true);
}
echo sprintf("[%0.5f] %s\n", microtime(true) - $start, $t);
}
还有时间:
[0.00000] Start 1
[0.02262] Assembled
[214.69091] All fetched... Going again!
[214.69105] prepared
[417.01584] fetching
[420.55217] all done
如您所见,获取所有变体和无缓冲变体几乎没有区别。
我在这里可能做错了什么?
谢谢!
【问题讨论】:
标签: php mysql pdo unbuffered-queries