Laravel Eloquent: 최대 'created_at'을 사용하여 모든 행 검색
Laravel에서는 최신 항목만 검색해야 할 때 공통 요구 사항이 발생합니다. 특정 열의 각 고유 값에 대한 행입니다. 각 행이 매출을 나타내는 제공된 테이블에서 각 판매자에 대한 가장 최근 매출을 얻고 싶을 수 있습니다.
Laravel Eloquent를 사용하여 이를 달성하기 위한 한 가지 접근 방식은 다음에서 제공된 쿼리를 수정하는 것입니다. 질문:
$sales = Snapshot::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();
이 쿼리는 별칭 's1'인 '스냅샷' 테이블의 복사본에 Left 조인을 도입하여 원하는 결과를 얻습니다. 조인은 'seller_id' 열을 기반으로 수행되며 'created_at' 값을 비교하여 각 판매자의 최신 행만 선택되도록 하는 조건을 포함합니다.
'whereNull' 절은 각 판매자에 대해 이를 보장합니다. 판매자의 경우 'created_at' 값이 더 큰 후속 행이 없습니다. 이는 각 고유 'seller_id'에 대해 최대 'created_at' 값이 있는 행을 식별합니다. 결과 쿼리에 대해 'get()'을 호출하면 판매자별로 그룹화된 모든 최신 매출의 배열을 얻습니다.
위 내용은 Laravel Eloquent를 사용하여 각 고유 판매자 ID에 대한 최신 행만 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!