用于选择按卖家分组的最新行的雄辩查询
给定一个包含卖家相关信息(包括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