首页 >后端开发 >php教程 >如何在 Laravel Eloquent 中为每个唯一的'seller_id”选择具有最大'created_at”的行?

如何在 Laravel Eloquent 中为每个唯一的'seller_id”选择具有最大'created_at”的行?

Linda Hamilton
Linda Hamilton原创
2024-10-25 12:15:30398浏览

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