> 데이터 베이스 > MySQL 튜토리얼 > Laravel Eloquent를 사용하여 각 판매자 ID에 대한 가장 최근 행을 얻는 방법은 무엇입니까?

Laravel Eloquent를 사용하여 각 판매자 ID에 대한 가장 최근 행을 얻는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-11-29 08:47:09
원래의
955명이 탐색했습니다.

How to Get the Most Recent Row for Each Seller ID Using Laravel Eloquent?

Laravel Eloquent를 사용하여 각 Seller_ID에 대한 최신 행을 선택하는 방법

문제

seller_id 및 Created_at 열이 있는 데이터가 포함된 테이블이 있습니다. 각 Seller_id에 대한 최신 행만 검색하고 싶습니다.

해결책

Laravel Eloquent의 쿼리 빌더를 사용하면 left Join과 whereNull 조건을 사용하여 이를 달성할 수 있습니다. 방법은 다음과 같습니다.

$subquery = DB::table('snapshot')
    ->where('seller_id', '=', 's1.seller_id')
    ->whereRaw('s.created_at < s1.created_at');

$query = DB::table('snapshot as s')
    ->select('s.*')
    ->leftJoinSub($subquery, 's1', function ($join) {
        $join->on('s.seller_id', '=', 's1.seller_id');
    })
    ->whereNull('s1.seller_id')
    ->get();
로그인 후 복사

이 쿼리에서:

  1. 하위 쿼리는 스냅샷 테이블에서 현재 행보다 나중에 생성된_at 타임스탬프가 있는 모든 행을 식별합니다.
  2. 왼쪽 조인은 기본 테이블(들)과 하위 쿼리 결과(s1)를 결합합니다.
  3. whereNull 조건은 하위 쿼리에 해당 항목이 존재하는 행을 제거합니다. 이렇게 하면 각 Seller_id의 최신 행을 제외한 모든 행이 효과적으로 필터링됩니다.

이 쿼리를 실행하면 스냅샷 테이블의 각 Seller_id에 대한 최신 행 컬렉션을 얻을 수 있습니다.

위 내용은 Laravel Eloquent를 사용하여 각 판매자 ID에 대한 가장 최근 행을 얻는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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