您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關yii2中batch和each有哪些區別的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
我們的數據庫常常都是很龐大的,一次查詢的結果集也很大,這樣很浪費內存,為了降低內存的使用率,我們可以使用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,這一點點代碼的優化幫你省掉了一半的內存。
感謝各位的閱讀!關于“yii2中batch和each有哪些區別”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。