首頁  >  文章  >  後端開發  >  Laravel中chunk組塊集處理

Laravel中chunk組塊集處理

炎欲天舞
炎欲天舞原創
2017-08-21 10:20:282332瀏覽

如果你需要處理成千上萬個 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條件是篩選approved0user然後將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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn