


Ausführliche Erklärung zur Verwendung von Lazy Collections zur Verbesserung der Leistung beim Lesen von Laravel Excel (unterstützt problemlos Millionen von Daten)
In Laravel 6 wurde eine neue Art von Sammlung hinzugefügt: Lazy Collections. Sie eignen sich hervorragend, wenn Sie sehr große Datensätze (Tausende oder Millionen Zeilen) verarbeiten müssen, ohne auf Speicherbeschränkungen zu stoßen.
Empfohlen: Laravel-Tutorial
Meine letzte Aufgabe bestand darin, den Excel-Export in einem Projekt bei der Arbeit umzugestalten. Das Problem besteht darin, dass der Export nicht mehr erstellt werden kann, da der Datensatz zu groß ist, als dass Laravel ihn verarbeiten könnte. Die Datenbankabfrage lieferte ca. 300.000 Ergebnisse! Bei der Anwendung tritt eine Zeitüberschreitung auf oder es ist ständig nicht mehr genügend Arbeitsspeicher vorhanden.
Ein naiver Ansatz besteht darin, das Timeout oder das Speicherlimit zu erhöhen und zu hoffen, dass das nächste Mal, wenn etwas schief geht, eine andere Person damit umgehen wird. Aber so arbeite ich nicht. Ich mag keine Pflaster. Ich mag konkrete, langfristige Lösungen.
Die Laravel Excel-Erweiterung ist bereits recht flexibel. Es leistet hervorragende Arbeit bei der Reduzierung der Datenbanklast durch die Verwendung von „Chunks“ bei der Verwendung von FromQuery-Anliegen. Unser Export hat jedoch immer noch Probleme mit großen Datensätzen.
Meine Kollegen und ich haben darüber gesprochen, ob wir diese Funktion komplett neu schreiben sollten: Den Export in eine Warteschlange verschieben und eine Benachrichtigung an den Benutzer senden, wenn der Export abgeschlossen ist. Allerdings ist diese Funktion in dieser App nur eine Nebensache. Es macht für uns keinen Sinn, nur für einen einfachen Export so viel Overhead hinzuzufügen.
Später an diesem Tag hatte ich einen kleinen „Heureka“-Moment, weil mir einfiel, dass Laravel LazyCollections hatte.
Ich habe den Export umgeschrieben: Er verwendet jetzt FromCollection-concern anstelle von FromQuery. Die einzige Änderung, die ich an der Methode „collection()“ vornehmen musste, bestand darin, die Methode „get()“ am Ende der Abfrage-Builder-Kette durch eine „cursor()“ zu ersetzen.
Nachfolgend finden Sie eine vereinfachte Version unserer Exportfunktion. Das Request-Objekt wird durch den Konstruktor geleitet, sodass wir die Abfrage basierend auf der Auswahl des Benutzers in der Benutzeroberfläche anpassen können.
<?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(); // ← 重要的一点 } }
Ich glaube, dass bei Ihrem Projekt Speicherprobleme auftreten. Sie haben das Speicherlimit erhöht und damit hoffentlich das Problem gelöst (ich habe das selbst schon unzählige Male gemacht).
Wenn es in einem Laravel-Projekt wäre, könnte ich Sie hoffentlich bitten, diesen Code noch einmal zu überprüfen und ihn mit LazyCollections neu zu schreiben.
Die Behebung dieses Problems hat wirklich Spaß gemacht, deshalb habe ich einen kleinen Benchmark durchgeführt: Unser Export kann jetzt problemlos Millionen von Zeilen exportieren, ohne an Speichergrenzen zu stoßen. So cool!
Das obige ist der detaillierte Inhalt vonAusführliche Erklärung zur Verwendung von Lazy Collections zur Verbesserung der Leistung beim Lesen von Laravel Excel (unterstützt problemlos Millionen von Daten). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Datenbankoperationen in PHP werden durch ORM vereinfacht, das Objekte in relationalen Datenbanken abbildet. EloquentORM in Laravel ermöglicht Ihnen die Interaktion mit der Datenbank mithilfe einer objektorientierten Syntax. Sie können ORM verwenden, indem Sie Modellklassen definieren, Eloquent-Methoden verwenden oder in der Praxis ein Blog-System erstellen.

Die neuesten Versionen von Laravel 9 und CodeIgniter 4 bieten aktualisierte Funktionen und Verbesserungen. Laravel9 übernimmt die MVC-Architektur und bietet Funktionen wie Datenbankmigration, Authentifizierung und Template-Engine. CodeIgniter4 nutzt die HMVC-Architektur, um Routing, ORM und Caching bereitzustellen. In Bezug auf die Leistung sorgen das auf Dienstanbietern basierende Designmuster von Laravel9 und das leichte Framework von CodeIgniter4 für eine hervorragende Leistung. In praktischen Anwendungen eignet sich Laravel9 für komplexe Projekte, die Flexibilität und leistungsstarke Funktionen erfordern, während CodeIgniter4 für schnelle Entwicklung und kleine Anwendungen geeignet ist.

Laravel – Artisan Commands – Laravel 5.7 bietet eine neue Möglichkeit, neue Befehle zu behandeln und zu testen. Es enthält eine neue Funktion zum Testen von Handwerkerbefehlen und die Demonstration wird unten erwähnt?

Vergleichen Sie die Datenverarbeitungsfunktionen von Laravel und CodeIgniter: ORM: Laravel verwendet EloquentORM, das eine relationale Klassen-Objekt-Zuordnung bereitstellt, während CodeIgniter ActiveRecord verwendet, um das Datenbankmodell als Unterklasse von PHP-Klassen darzustellen. Abfrage-Builder: Laravel verfügt über eine flexible verkettete Abfrage-API, während der Abfrage-Builder von CodeIgniter einfacher und Array-basiert ist. Datenvalidierung: Laravel bietet eine Validator-Klasse, die benutzerdefinierte Validierungsregeln unterstützt, während CodeIgniter über weniger integrierte Validierungsfunktionen verfügt und eine manuelle Codierung benutzerdefinierter Regeln erfordert. Praxisfall: Beispiel einer Benutzerregistrierung zeigt Lar

Für Anfänger bietet CodeIgniter eine sanftere Lernkurve und weniger Funktionen, deckt aber die Grundbedürfnisse ab. Laravel bietet einen größeren Funktionsumfang, weist jedoch eine etwas steilere Lernkurve auf. In Bezug auf die Leistung schneiden sowohl Laravel als auch CodeIgniter gut ab. Laravel verfügt über eine umfangreichere Dokumentation und aktive Community-Unterstützung, während CodeIgniter einfacher und leichtgewichtiger ist und über starke Sicherheitsfunktionen verfügt. Im praktischen Fall der Erstellung einer Blogging-Anwendung vereinfacht EloquentORM von Laravel die Datenmanipulation, während CodeIgniter mehr manuelle Konfiguration erfordert.

Bei der Auswahl eines Frameworks für große Projekte haben Laravel und CodeIgniter jeweils ihre eigenen Vorteile. Laravel ist für Anwendungen auf Unternehmensebene konzipiert und bietet modularen Aufbau, Abhängigkeitsinjektion und einen leistungsstarken Funktionsumfang. CodeIgniter ist ein leichtes Framework, das sich eher für kleine bis mittelgroße Projekte eignet und Wert auf Geschwindigkeit und Benutzerfreundlichkeit legt. Für große Projekte mit komplexen Anforderungen und einer großen Anzahl von Benutzern sind die Leistung und Skalierbarkeit von Laravel besser geeignet. Für einfache Projekte oder Situationen mit begrenzten Ressourcen sind die leichten und schnellen Entwicklungsfunktionen von CodeIgniter idealer.

Leitfaden zum Testen von PHP-Einheiten und -Integrationen Unit-Tests: Konzentrieren Sie sich auf eine einzelne Code- oder Funktionseinheit und verwenden Sie PHPUnit, um Testfallklassen zur Überprüfung zu erstellen. Integrationstests: Achten Sie darauf, wie mehrere Codeeinheiten zusammenarbeiten, und verwenden Sie die Methoden setUp() und TearDown() von PHPUnit, um die Testumgebung einzurichten und zu bereinigen. Praktischer Fall: Verwenden Sie PHPUnit, um Unit- und Integrationstests in Laravel-Anwendungen durchzuführen, einschließlich der Erstellung von Datenbanken, dem Starten von Servern und dem Schreiben von Testcode.

Für kleine Projekte eignet sich Laravel, für größere Projekte, die starke Funktionalität und Sicherheit erfordern. CodeIgniter eignet sich für sehr kleine Projekte, die geringes Gewicht und Benutzerfreundlichkeit erfordern.
