用於選擇按賣家分組的最新行的雄辯查詢
給定一個包含賣家相關資訊(包括created_at時間戳)的表,通常需要僅檢索每個賣家的最新條目。使用 Laravel Eloquent 可以有效地完成此任務。
為了實現這一目標,我們可以使用 MySQL 子查詢,該子查詢使用左連接和 NULL 匹配來標識每個 seller_id 的最新行。然後可以將此子查詢與 Eloquent 結合使用來檢索所需的資料。
在 SQL 中,查詢如下所示:
select s.*
from snapshot s
left join snapshot s1 on s.seller_id = s1.seller_id
and s.created_at 翻譯成 Laravel Eloquent,查詢會寫成如下:
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 whereNull('s1.seller_id')
->get();
此查詢使用子查詢來擷取每個唯一 seller_id 的最新快照行,確保傳回的結果代表每個賣家的最新資訊。
免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。
Copyright© 2022 湘ICP备2022001581号-3