首頁  >  文章  >  php框架  >  yii2 batch和each的差別是什麼

yii2 batch和each的差別是什麼

爱喝马黛茶的安东尼
爱喝马黛茶的安东尼原創
2019-12-09 10:58:583853瀏覽

yii2 batch和each的差別是什麼

我們的資料庫常常都是很龐大的,一次查詢的結果集也很大,這樣很浪費內存,為了降低內存的使用率,我們可以使用yii2的batch和each方法。

為了讓大家看的更明白,我們模擬一個場景,然後透過yii2的debug來查看all與batch/each方法下的記憶體使用情況。

開始準備

我們先建立一張表,它很簡單。

yii2 batch和each的差別是什麼

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

然後,我們執行了一個迴圈

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

執行後,你知道我們的資料庫裡有10000筆記錄了,現在我們開始比較。

比較

為了方便,我們在視圖裡直接寫循環體,如下面程式碼,你一定可以看懂。

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

結果那?

yii2 batch和each的差別是什麼

佔有記憶體 15.306MB

OK,現在開始看看batch和each的戲法,到底有沒有節省記憶體。

$query = new \yii\db\Query();
$query->from(&#39;user&#39;);
foreach($query->batch() as $users){
        foreach($users as $user){
        echo $user[&#39;username&#39;];
        echo "<br/>";
    }
}

結果那?

yii2 batch和each的差別是什麼

果然,節省了一半的記憶體。現在僅僅佔用了8.077MB

同樣的

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

each的表現也相當不錯

yii2 batch和each的差別是什麼

結果

當我們遇到需要一次讀取出所有的或是大批量資料的時候,可以考慮使用batch和each,這一點點程式碼的最佳化幫你省掉了一半的記憶體。

PHP中文網,有大量免費的Yii入門教學,歡迎大家學習!

以上是yii2 batch和each的差別是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn