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
Patricia ArquetteOriginal
2025-01-03 04:46:39501Durchsuche

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');

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();

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!

Stellungnahme:
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