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