Eloquente Abfrage zum Auswählen der neuesten Zeilen, gruppiert nach Verkäufer
Bei einer Tabelle mit verkäuferbezogenen Informationen, einschließlich erstellter_at-Zeitstempeln, ist dies häufig erforderlich Rufen Sie für jeden Verkäufer nur die aktuellsten Einträge ab. Diese Aufgabe kann mit Laravel Eloquent effektiv gelöst werden.
Um dies zu erreichen, können wir eine MySQL-Unterabfrage verwenden, die die neueste Zeile für jede seller_id mithilfe eines Left-Joins und eines NULL-Abgleichs identifiziert. Diese Unterabfrage kann dann in Verbindung mit Eloquent verwendet werden, um die gewünschten Daten abzurufen.
In SQL würde die Abfrage so aussehen:
<code class="sql">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
Übersetzt in Laravel Eloquent würde die Abfrage lauten geschrieben wie folgt:
<code class="php">DB::table('snapshot as s') ->select('s.*') ->leftJoin('snapshot as s1', function ($join) { $join->on('s.seller_id', '=', 's1.seller_id') ->whereRaw(DB::raw('s.created_at < s1.created_at')); }) ->whereNull('s1.seller_id') ->get();</code>
Diese Abfrage ruft mithilfe der Unterabfrage die neueste Snapshot-Zeile für jede eindeutige seller_id ab und stellt so sicher, dass die zurückgegebenen Ergebnisse die aktuellsten Informationen für jeden Verkäufer darstellen.
Das obige ist der detaillierte Inhalt vonWie rufe ich mit Laravel Eloquent den neuesten Snapshot für jeden Verkäufer ab?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!