第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

PDO :: fetchAll與PDO :: fetch在循環(huán)中

PDO :: fetchAll與PDO :: fetch在循環(huán)中

慕慕森 2019-10-09 15:59:36
只是一個簡單的問題。在循環(huán)中使用PDO :: fetchAll()和PDO :: fetch()是否有性能差異(對于大型結果集)?我正在獲取用戶定義類的對象,如果有什么不同的話。我最初的未經教育的假設是fetchAll可能會更快,因為PDO可以在一條語句中執(zhí)行多個操作,而mysql_query只能執(zhí)行一條。但是,我對PDO的內部工作原理知之甚少,文檔也對此一無所知,而fetchAll()是否只是轉儲到數組中的PHP端循環(huán)。有什么幫助嗎?
查看完整描述

3 回答

?
米琪卡哇伊

TA貢獻1998條經驗 獲得超6個贊

幾乎沒有200k隨機記錄的基準。與預期的一樣,fetchAll方法更快,但需要更多的內存。


Result :

fetchAll : 0.35965991020203s, 100249408b

fetch : 0.39197015762329s, 440b

使用的基準代碼:


<?php

// First benchmark : speed

$dbh = new PDO('mysql:dbname=testage;dbhost=localhost', 'root', '');

$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

$sql = 'SELECT * FROM test_table WHERE 1';

$stmt = $dbh->query($sql);

$data = array();

$start_all = microtime(true);

$data = $stmt->fetchAll();

$end_all = microtime(true);


$stmt = $dbh->query($sql);

$data = array();

$start_one = microtime(true);

while($data = $stmt->fetch()){}

$end_one = microtime(true);


// Second benchmark : memory usage

$stmt = $dbh->query($sql);

$data = array();

$memory_start_all = memory_get_usage();

$data = $stmt->fetchAll();

$memory_end_all = memory_get_usage();


$stmt = $dbh->query($sql);

$data = array();

$memory_end_one = 0;

$memory_start_one = memory_get_usage();

while($data = $stmt->fetch()){

  $memory_end_one = max($memory_end_one, memory_get_usage());

}


echo 'Result : <br/>

fetchAll : ' . ($end_all - $start_all) . 's, ' . ($memory_end_all - $memory_start_all) . 'b<br/>

fetch : ' . ($end_one - $start_one) . 's, ' . ($memory_end_one - $memory_start_one) . 'b<br/>';


查看完整回答
反對 回復 2019-10-09
?
繁花不似錦

TA貢獻1851條經驗 獲得超4個贊

我發(fā)現關于PHP的一件事幾乎總是如此,那就是您自己實現的功能幾乎總是比同等的PHP慢。這是因為,當用PHP實現某些東西時,它沒有C所具有的所有編譯時優(yōu)化(PHP編寫在其中),并且PHP函數調用的開銷很大。


查看完整回答
反對 回復 2019-10-09
?
當年話下

TA貢獻1890條經驗 獲得超9個贊

// $data in this case is an array of rows;


$data = $stmt->fetchAll();



// $data in this case is just one row after each loop;


while($data = $stmt->fetch()){}



// Try using


$i = 0;


while($data[$i++] = $stmt->fetch()){}

內存差異應該可以忽略不計


查看完整回答
反對 回復 2019-10-09
  • 3 回答
  • 0 關注
  • 1205 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號