關於使用 Lazy Collections 來提高 Laravel Excel 讀取的效能詳解(輕鬆支援百萬資料)
在 Laravel 6 中新增了一個新類型的集合: Lazy Collections。如果需要處理非常大的資料集(數千或數百萬行)而不會遇到記憶體限制,那麼它們是非常棒的。
推薦:laravel教學
我最近的任務是在工作中的一個專案中重構 Excel 匯出。問題是,由於資料集太大,Laravel 無法處理,匯出無法再建立。資料庫查詢回傳了大約 300,000 個結果!應用程式產生超時或一直記憶體不足。
一種天真的方法是增加超時時間或記憶體限制,並希望下次出現問題時,另一個人會處理這個問題。但這不是我的工作方式。我不喜歡創可貼。我喜歡具體的、長期的解決方案。
Laravel Excel 擴充包已經相當靈活。透過在使用 FromQuery-concerns 時使用“chunks”,它在減少資料庫負載方面做得很好。然而,我們的導出仍然很難處理大數據集。
我和我的同事討論過,我們是否應該完全重寫這個特性:將匯出推送到佇列中,並在匯出結束時向用戶發送通知。然而,這個功能在這個應用程式中只是一個很小的東西。對我們來說,僅僅為了一個簡單的導出而增加如此多的開銷是沒有意義的。
那天晚些時候,我有一個小小的“我發現了”的時刻,因為我記得 Laravel 中有 LazyCollections 這個東東。
我重新編寫了導出:它現在使用 FromCollection-concern,而不是 FromQuery。我必須對 collection() 方法進行的惟一更改是將查詢建構器鏈末尾的 get() 方法替換為 cursor()。
以下是我們匯出功能的簡化版本。 Request 物件透過建構函數傳遞,因此我們可以根據使用者在 UI 中選擇的內容對查詢進行調整。
<?php namespace App\Exports; use App\User; use Maatwebsite\Excel\Concerns\Exportable; use Maatwebsite\Excel\Concerns\FromCollection; use Illuminate\Http\Request; class UsersExport implements FromCollection { use Exportable; protected Request $request; public function __construct(Request $request) { $this->request = $request; } public function collection() { return User::query() ->when($this->request->get('include_subscribed'), function ($q) { return $q->where('is_subscribed', true); }) ->cursor(); // ← 重要的一点 } }
我相信你在你的專案中遇到了記憶體問題。你增加了記憶體限制,希望問題已經解決了 (我自己已經做過無數次了)。
如果是在 Laravel 專案中,我希望,我可以讓你重新查看程式碼並使用 LazyCollections 重寫。
修復這個問題非常有趣,所以我做了一個小小的基準測試:我們的匯出現在可以輕鬆地匯出數百萬行,而不會遇到記憶體限制。太酷了!
以上是關於使用 Lazy Collections 來提高 Laravel Excel 讀取的效能詳解(輕鬆支援百萬資料)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

在dcatadmin(laravel-admin)中如何實現自定義點擊添加數據的表格功能在使用dcat...

Laravel郵件發送失敗時的退信代碼獲取方法在使用Laravel開發應用時,經常會遇到需要發送驗證碼的情況。而在實�...

Laravel框架中Redis連接的共享與select方法的影響在使用Laravel框架和Redis時,開發者可能會遇到一個問題:通過配置...

在Laravel多租戶擴展包stancl/tenancy中自定義租戶數據庫連接使用Laravel多租戶擴展包stancl/tenancy構建多租戶應用時,...

LaravelEloquent模型檢索:輕鬆獲取數據庫數據EloquentORM提供了簡潔易懂的方式來操作數據庫。本文將詳細介紹各種Eloquent模型檢索技巧,助您高效地從數據庫中獲取數據。 1.獲取所有記錄使用all()方法可以獲取數據庫表中的所有記錄:useApp\Models\Post;$posts=Post::all();這將返回一個集合(Collection)。您可以使用foreach循環或其他集合方法訪問數據:foreach($postsas$post){echo$post->

在Laravel6項目中如何檢查Redis連接的有效性是一個常見的問題,特別是在項目依賴於Redis進行業務處理時。以下是...

Laravel 是一款 PHP 框架,用於輕鬆構建 Web 應用程序。它提供一系列強大的功能,包括:安裝: 使用 Composer 全局安裝 Laravel CLI,並在項目目錄中創建應用程序。路由: 在 routes/web.php 中定義 URL 和處理函數之間的關係。視圖: 在 resources/views 中創建視圖以呈現應用程序的界面。數據庫集成: 提供與 MySQL 等數據庫的開箱即用集成,並使用遷移來創建和修改表。模型和控制器: 模型表示數據庫實體,控制器處理 HTTP 請求。

Laravel數據庫遷移過程中出現類重複定義問題在使用Laravel框架進行數據庫遷移時,開發者可能會遇到“類已使用�...
