Yii2中你可能忽略但頗有用的兩個方法batch&each

咱們的數據庫經常都是很龐大的,一次查詢的結果集也很大,這樣很浪費內存,爲了下降內存的使用率,咱們可使用yii2的batch和each方法。php

爲了讓你們看的更明白,咱們模擬一個場景,而後經過yii2的debug來查看all與batch/each方法下的內存使用狀況。數據庫

開始準備

咱們先創建一張表,它很簡單。
圖片描述yii2

你看到了,它有主鍵id、會員名username、所在省province,如今它是空的。app

而後,咱們執行了一個循環yii

set_time_limit(0);
for($i=1;$i<=10000;$i++){
    Yii::$app->db->createCommand()->insert("user",[
        'username'=>'abei'.$i,
        'province'=>'北京市'
    ])->execute();
}

執行後,你知道咱們的數據庫裏有10000條記錄了,如今咱們開始對比。優化

對比

爲了方便,咱們在視圖裏直接寫循環體,以下面代碼,你必定能夠看懂。spa

$query = new \yii\db\Query();
$query->from('user');
foreach($query->all() as $user){
    echo $user['username'];
    echo "<br/>";
}

結果那?debug

圖片描述

佔有內存 15.306MBcode

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,這一點點代碼的優化幫你省掉了一半的內存。

相關文章
相關標籤/搜索