首页  >  文章  >  后端开发  >  如何使用 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