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中文网其他相关文章!