Heim > Datenbank > MySQL-Tutorial > Wie kann man in Laravel eloquente SUM- und GROUP BY-Abfragen effizient durchführen?

Wie kann man in Laravel eloquente SUM- und GROUP BY-Abfragen effizient durchführen?

Patricia Arquette
Freigeben: 2025-01-03 04:46:39
Original
497 Leute haben es durchsucht

How to Efficiently Perform Eloquent SUM and GROUP BY Queries in Laravel?

Eloquente Summen- und Gruppierungsabfragen in Laravel

In Laravel bietet das Eloquent ORM eine bequeme Möglichkeit, mit der Datenbank zu interagieren. Bei der Arbeit mit großen Datensätzen kann es jedoch notwendig werden, komplexe Abfragen durchzuführen, die Aggregationsfunktionen wie SUM mit Gruppierungsoperationen wie GROUP BY kombinieren.

Die Herausforderung

Eins Diese Frage stellt sich häufig, wenn Sie die Summe eines bestimmten Felds ermitteln und die Ergebnisse nach einem anderen Feld gruppieren möchten. Beispielsweise möchten Sie möglicherweise die Gesamtzahl der von jedem Herausgeber geschriebenen Seiten in einer Dokumentdatenbank ermitteln.

Lösung 1: Verwenden von selectRaw und pluck

Um dies zu erreichen können Sie die Ergebnisse zunächst mit der Methode „groupBy“ nach dem gewünschten Feld gruppieren. Verwenden Sie dann die Methode „selectRaw“, um die Berechnung zu definieren, und verwenden Sie schließlich die Methode „pluck“, um ein Array der Summe für jede Gruppe zu erstellen:

Document::groupBy('users_editor_id')
   ->selectRaw('SUM(no_of_pages) AS sum, users_editor_id')
   ->pluck('sum', 'users_editor_id');
Nach dem Login kopieren

Lösung 2: Verwenden von „selectRaw“ und „get“

Alternativ können Sie ein ähnliches Ergebnis mit den Methoden selectRaw und get erzielen. Dieser Ansatz gibt jedoch eine Sammlung von Pseudomodellen zurück, die die berechnete Summe als zusätzliches Feld enthält:

Document::groupBy('users_editor_id')
   ->selectRaw('*, SUM(no_of_pages) AS sum')
   ->get();
Nach dem Login kopieren

Durch die Nutzung dieser Techniken können Sie komplexe Aggregations- und Gruppierungsvorgänge in Ihren Eloquent-Abfragen effizient durchführen Gewinnen Sie wertvolle Erkenntnisse aus Ihrer Datenbank.

Das obige ist der detaillierte Inhalt vonWie kann man in Laravel eloquente SUM- und GROUP BY-Abfragen effizient durchführen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage