溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

yii2中batch和each有哪些區(qū)別

發(fā)布時間:2021-01-11 14:47:16 來源:億速云 閱讀:311 作者:小新 欄目:編程語言

這篇文章給大家分享的是有關(guān)yii2中batch和each有哪些區(qū)別的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

我們的數(shù)據(jù)庫常常都是很龐大的,一次查詢的結(jié)果集也很大,這樣很浪費內(nèi)存,為了降低內(nèi)存的使用率,我們可以使用yii2的batch和each方法。

為了讓大家看的更明白,我們模擬一個場景,然后通過yii2的debug來查看all與batch/each方法下的內(nèi)存使用情況。

開始準(zhǔn)備

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

yii2中batch和each有哪些區(qū)別

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

然后,我們執(zhí)行了一個循環(huán)

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

執(zhí)行后,你知道我們的數(shù)據(jù)庫里有10000條記錄了,現(xiàn)在我們開始對比。

對比

為了方便,我們在視圖里直接寫循環(huán)體,如下面代碼,你一定可以看懂。

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

結(jié)果那?

yii2中batch和each有哪些區(qū)別

占有內(nèi)存 15.306MB

OK,現(xiàn)在開始看看batch和each的戲法,到底有沒有節(jié)省內(nèi)存。

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

結(jié)果那?

yii2中batch和each有哪些區(qū)別

果然,節(jié)省了一半的內(nèi)存。現(xiàn)在僅僅占用了8.077MB

同樣的

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

each的表現(xiàn)也相當(dāng)不錯

yii2中batch和each有哪些區(qū)別

結(jié)果

當(dāng)我們遇到需要一次讀取出所有的或是大批量數(shù)據(jù)的時候,可以考慮使用batch和each,這一點點代碼的優(yōu)化幫你省掉了一半的內(nèi)存。

感謝各位的閱讀!關(guān)于“yii2中batch和each有哪些區(qū)別”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI