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!