Yii2中你可能忽略但很有用的兩個方法batch&each
阿新 • • 發佈:2019-05-20
我們的資料庫常常都是很龐大的,一次查詢的結果集也很大,這樣很浪費記憶體,為了降低記憶體的使用率,我們可以使用yii2的batch和each方法。
為了讓大家看的更明白,我們模擬一個場景,然後通過yii2的debug來檢視all與batch/each方法下的記憶體使用情況。
開始準備
我們先建立一張表,它很簡單。
你看到了,它有主鍵id、會員名username、所在省province,現在它是空的。
然後,我們執行了一個迴圈
set_time_limit(0); for($i=1;$i<=10000;$i++){ Yii::$app->db->createCommand()->insert("user",[ 'username'=>'abei'.$i, 'province'=>'北京市' ])->execute(); }
執行後,你知道我們的資料庫裡有10000條記錄了,現在我們開始對比。
對比
為了方便,我們在視圖裡直接寫迴圈體,如下面程式碼,你一定可以看懂。
$query = new \yii\db\Query();
$query->from('user');
foreach($query->all() as $user){
echo $user['username'];
echo "<br/>";
}
結果那?
佔有記憶體 15.306MB
OK,現在開始看看batch和each的戲法,到底有沒有節省記憶體。
$query = new \yii\db\Query(); $query->from('user'); foreach($query->batch() as $users){ foreach($users as $user){ echo $user['username']; echo "<br/>"; } }
結果那?
果然,節省了一半的記憶體。現在僅僅佔用了8.077MB
同樣的
$query = new \yii\db\Query();
$query->from('user');
foreach($query->each() as $user){
echo $user['username'];
echo "<br/>";
}
each的表現也相當不錯
結果
當我們遇到需要一次讀取出所有的或是大批量資料的時候,可以考慮使用batch和each,這一點點程式碼的優化幫你省掉了