> 데이터 베이스 > MySQL 튜토리얼 > Laravel Eloquent를 사용하여 각 고유 판매자 ID에 대한 최신 행만 검색하는 방법은 무엇입니까?

Laravel Eloquent를 사용하여 각 고유 판매자 ID에 대한 최신 행만 검색하는 방법은 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2024-11-27 21:35:16
원래의
510명이 탐색했습니다.

How to Retrieve Only the Latest Rows for Each Unique Seller ID using Laravel Eloquent?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿