> 데이터 베이스 > MySQL 튜토리얼 > Laravel에서 Eloquent SUM 및 GROUP BY 쿼리를 효율적으로 수행하는 방법은 무엇입니까?

Laravel에서 Eloquent SUM 및 GROUP BY 쿼리를 효율적으로 수행하는 방법은 무엇입니까?

Patricia Arquette
풀어 주다: 2025-01-03 04:46:39
원래의
509명이 탐색했습니다.

How to Efficiently Perform Eloquent SUM and GROUP BY Queries in Laravel?

Laravel의 Eloquent Sum 및 Group By 쿼리

Laravel에서 Eloquent ORM은 데이터베이스와 상호 작용하는 편리한 방법을 제공합니다. 그러나 대규모 데이터 세트로 작업할 때는 SUM과 같은 집계 기능을 GROUP BY와 같은 그룹화 작업과 결합하는 복잡한 쿼리를 수행해야 할 수 있습니다.

과제

One 이 질문이 발생하는 일반적인 시나리오는 결과를 다른 필드별로 그룹화하면서 특정 필드의 합계를 얻으려는 경우입니다. 예를 들어, 문서 데이터베이스에서 각 편집자가 작성한 총 페이지 수를 찾고 싶을 수 있습니다.

해결책 1: selectRaw 및 pluck 사용

이를 달성하려면 , 먼저 groupBy 메서드를 사용하여 원하는 필드별로 결과를 그룹화할 수 있습니다. 그런 다음 selectRaw 메서드를 사용하여 계산을 정의하고 마지막으로 pluck 메서드를 사용하여 각 그룹에 대한 합계 배열을 만듭니다.

Document::groupBy('users_editor_id')
   ->selectRaw('SUM(no_of_pages) AS sum, users_editor_id')
   ->pluck('sum', 'users_editor_id');
로그인 후 복사

해결책 2: selectRaw 및 get 사용

또는 selectRaw 및 get 메소드를 사용하여 비슷한 결과를 얻을 수 있습니다. 그러나 이 접근 방식은 계산된 합계를 추가 필드로 포함하는 의사 모델 모음을 반환합니다.

Document::groupBy('users_editor_id')
   ->selectRaw('*, SUM(no_of_pages) AS sum')
   ->get();
로그인 후 복사

이러한 기술을 활용하면 Eloquent 쿼리에서 복잡한 집계 및 그룹화 작업을 효율적으로 수행할 수 있습니다. 데이터베이스에서 귀중한 통찰력을 얻으세요.

위 내용은 Laravel에서 Eloquent SUM 및 GROUP BY 쿼리를 효율적으로 수행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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