如果你需要處理成千上萬個 Eloquent 結果,可以使用 chunk
指令。 chunk
方法會取得一個「組塊」的 Eloquent 模型,並將其填入給定閉包進行處理。使用 chunk
方法能夠在處理大量資料集合時能夠有效減少記憶體消耗:
Flight::chunk(200, function ($flights) { foreach ($flights as $flight) { // } });
$all_ark=Arkvolume::chunk(50000, function ($flights) { foreach ($flights as $flight) { $GLOBALS['something'][] = $flight['id']; } }); var_dump($GLOBALS['something'] );exit;
這段程式碼是執行一個100條的資料進行更新,當執行完成後繼續後面的另一百個資料…
也就是說他每次操作的是一個資料區塊而不是整個資料庫。
要注意的是:當使用帶有篩選的條件的chunk時,如果是自更新,那麼你會漏掉一些數據,接著看代碼:
User::where('approved', 0)->chunk(100, function ($users) { foreach ($users as $user) { $user->update(['approved' => 1]); } });
如果要執行上面的程式碼,不會有報錯,但是where
條件是篩選approved
為0
的user
然後將approved
的值跟新為1
。
在這個過程中,檔第一資料庫的資料被修改後,下一個資料區塊的資料將是在被修改後的資料中選出來的,這個時候資料變了,而page也加了1。所以執行結束後,只對資料中一半的資料進行了更新操作。
如果沒有明白的話,我們來看看chunk的底層實作。也以上面的程式碼為例,如果一共有400個數據,數據就被依照100條進行分塊處理。
page = 1: 最開始的時候page為1,選取1-100條資料進行處理;
page = 2: 這時候前一百資料的approved
值全部為1,那麼在次篩選的時候資料將從第101條開始,而這個時候的page=2,那麼處理的資料將是第200-300之前的資料
之後依舊。
public function chunk($count, callable $callback) { $results = $this->forPage($page = 1, $count)->get(); while (count($results) > 0) { // On each chunk result set, we will pass them to the callback and then let the // developer take care of everything within the callback, which allows us to // keep the memory low for spinning through large result sets for working. if (call_user_func($callback, $results) === false) { return false; } $page++; $results = $this->forPage($page, $count)->get(); } return true; }
以上是Laravel中chunk組塊集處理的詳細內容。更多資訊請關注PHP中文網其他相關文章!