bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

yii2中batch和each有哪些區別-創新互聯

這篇文章給大家分享的是有關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",[
        'username'=>'abei'.$i,
        'province'=>'北京市'
    ])->execute();
}

執行后,你知道我們的數據庫里有10000條記錄了,現在我們開始對比。

對比

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

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

結果那?

yii2中batch和each有哪些區別

占有內存 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/>";
    }
}

結果那?

yii2中batch和each有哪些區別

果然,節省了一半的內存。現在僅僅占用了8.077MB

同樣的

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

each的表現也相當不錯

yii2中batch和each有哪些區別

結果

當我們遇到需要一次讀取出所有的或是大批量數據的時候,可以考慮使用batch和each,這一點點代碼的優化幫你省掉了一半的內存。

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

文章題目:yii2中batch和each有哪些區別-創新互聯
當前網址:http://vcdvsql.cn/article30/djjdso.html

成都網站建設公司_創新互聯,為您提供網站營銷靜態網站定制網站網站維護小程序開發網頁設計公司

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

搜索引擎優化