首頁  >  文章  >  後端開發  >  如何使用 Laravel Eloquent 取得每個賣家的最新快照?

如何使用 Laravel Eloquent 取得每個賣家的最新快照?

Mary-Kate Olsen
Mary-Kate Olsen原創
2024-10-26 13:55:02179瀏覽

How to Fetch the Latest Snapshot for Each Seller Using Laravel Eloquent?

用於選擇按賣家分組的最新行的雄辯查詢

給定一個包含賣家相關資訊(包括created_at時間戳)的表,通常需要僅檢索每個賣家的最新條目。使用 Laravel Eloquent 可以有效地完成此任務。

為了實現此目的,我們可以使用 MySQL 子查詢,該子查詢使用左連接和 NULL 匹配來標識每個 seller_id 的最新行。然後可以將此子查詢與 Eloquent 結合使用來檢索所需的資料。

在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 Eloquent,查詢將是編寫如下:

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

此查詢使用子查詢檢索每個唯一的seller_id 的最新快照行,確保傳回的結果代表每個賣家的最新資訊。

以上是如何使用 Laravel Eloquent 取得每個賣家的最新快照?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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