首頁 >後端開發 >php教程 >如何在 Laravel Eloquent 中為每個唯一的'seller_id”選擇具有最大'created_at”的行?

如何在 Laravel Eloquent 中為每個唯一的'seller_id”選擇具有最大'created_at”的行?

Linda Hamilton
Linda Hamilton原創
2024-10-25 12:15:30384瀏覽

How to Select Rows with the Maximum `created_at` for Each Unique `seller_id` in Laravel Eloquent?

Laravel Eloquent:選擇具有最大Created_at 的行

在Laravel Eloquent 中,你可能會遇到需要選擇具有最大值的所有最大值行的場景表中每個唯一的seller_id 的created_at 值。以下是實現此目的的方法:

使用原始SQL 查詢

一種方法是使用原始SQL 查詢,這在某些情況下可能會更有效:

<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

使用查詢產生器

或者,您可以利用Laravel 的查詢產生器來實現更物件導向的方法:

<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('s.created_at < s1.created_at');
   })
  ->whereNull('s1.seller_id')
  ->get();</code>

兩種方法都會傳回代表快照表中每個唯一seller_id 的最新行的物件集合。

以上是如何在 Laravel Eloquent 中為每個唯一的'seller_id”選擇具有最大'created_at”的行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn