日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Yii2中你可能忽略但很有用的两个方法batcheach

發布時間:2025/7/14 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Yii2中你可能忽略但很有用的两个方法batcheach 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

2019獨角獸企業重金招聘Python工程師標準>>>

我們的數據庫常常都是很龐大的,一次查詢的結果集也很大,這樣很浪費內存,為了降低內存的使用率,我們可以使用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,這一點點代碼的優化幫你省掉了一半的內存。

轉載于:https://my.oschina.net/u/3371661/blog/3051794

總結

以上是生活随笔為你收集整理的Yii2中你可能忽略但很有用的两个方法batcheach的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。