Laravel Eloquent: Alle neuesten Zeilen für jede Verkäufer-ID auswählen
Stellen Sie sich eine Tabelle vor, die Transaktionen enthält Datensätze:
Das Ziel besteht darin, die letzte Transaktion abzurufen für jede eindeutige seller_id. Während es einfach ist, die letzte Transaktion für einen bestimmten Verkäufer zu erhalten, besteht die Herausforderung darin, die neuesten Datensätze für alle Verkäufer zu extrahieren.
Datenbankabfrageansatz:
Ein effizienter Die Methode besteht darin, eine SQL-Abfrage zu verwenden:
select s.* from snapshot s left join snapshot s1 on s.seller_id = s1.seller_id and s.created_at < s1.created_at where s1.seller_id is null
Diese Abfrage identifiziert die letzte Transaktion für jede seller_id, indem sie einen Self-Join verwendet und Ausschließen von Datensätzen mit einem später erstellten_at-Zeitpunkt.
Laravel Query Builder-Ansatz:
Um das gleiche Ergebnis mit Laravel Query Builder zu erzielen:
DB::table('snapshot as s') ->select('s.*') ->leftJoin('snapshot as s1', function ($join) { $join->on('s.seller_id', '=', 's1.seller_id') ->whereRaw('s.created_at < s1.created_at'); }) ->whereNull('s1.seller_id') ->get();
Dieser Code verwendet eine ähnliche Self-Join-Technik wie die SQL-Abfrage und gibt die letzte Transaktion für jede Verkäufer-ID zurück.
Das obige ist der detaillierte Inhalt vonWie kann man mit Laravel Eloquent effizient die neueste Transaktion für jeden Verkäufer auswählen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!