Laravel Eloquent: GroupBy로 합산 기술 익히기
Laravel Eloquent를 사용하다 보면 합을 계산해야 할 때가 있습니다. 특정 열의 결과를 다른 열로 그룹화하는 동안 그러나 sum() 다음에 groupBy()를 사용하는 일반적인 접근 방식을 사용하면 오류가 발생할 수 있습니다. 이는 sum()이 쿼리를 즉시 실행하고 groupBy()를 적용할 개체를 남기지 않기 때문입니다.
대답: 그룹화 및 합산을 위한 숙련된 솔루션
해결 방법 이 문제의 해결 방법은 다음 코드 구조를 사용하는 것입니다.
Document::groupBy('users_editor_id') ->selectRaw('sum(no_of_pages) as sum, users_editor_id') ->pluck('sum','users_editor_id');
이 코드 groupBy()는 'users_editor_id' 열을 선택한 다음 selectRaw()를 사용하여 합계 계산을 지정합니다. 마지막으로 pluck()는 sum 및 users_editor_id` 값을 배열로 추출합니다.
또는 다음 접근 방식을 사용할 수 있습니다.
Document::groupBy('users_editor_id') ->selectRaw('*, sum(no_of_pages) as sum') ->get();
이 메서드는 추가 항목이 포함된 문서 모델 컬렉션을 반환합니다. 합계 필드는 그룹화된 합계에 대해 약간 다른 표현을 제공합니다. data.
결론
groupBy()와 sum() 사이의 상호 작용을 이해하고 selectRaw() 메서드를 활용하면 결과를 그룹화하면서 손쉽게 합계를 계산할 수 있습니다. Laravel Eloquent는 데이터 분석 기능을 강화합니다.
위 내용은 Laravel Eloquent에서 올바르게 합산하고 GroupBy하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!