> 데이터 베이스 > MySQL 튜토리얼 > Laravel Eloquent에서 GroupBy를 사용하여 합계를 올바르게 계산하는 방법은 무엇입니까?

Laravel Eloquent에서 GroupBy를 사용하여 합계를 올바르게 계산하는 방법은 무엇입니까?

Barbara Streisand
풀어 주다: 2024-12-30 00:11:39
원래의
543명이 탐색했습니다.

How to Correctly Calculate Sum with GroupBy in Laravel Eloquent?

Laravel Eloquent에서 GroupBy를 사용하여 합계 계산

Laravel에서 Eloquent ORM은 데이터베이스와 상호 작용하는 강력한 방법을 제공합니다. 일반적인 작업 중 하나는 특정 필드별로 그룹화하면서 열의 합계를 계산하는 것입니다. sum() 메서드를 사용하는 것은 간단해 보이지만 실행 순서로 인해 오류가 발생할 수 있습니다.

잘못된 접근 방법

$this->data['no_of_pages'] = Document::sum('no_of_pages')
                            ->groupBy('users_editor_id'); // Call to undefined method
로그인 후 복사

위 코드에서, groupBy() 메서드는 sum() 메서드 다음에 호출되는데, 이는 sum()이 쿼리를 실행하고 groupBy()가 호출되기 전에 결과를 반환하므로 오류가 발생합니다. 적용되었습니다.

올바른 솔루션

groupBy를 사용하여 합계를 올바르게 계산하려면 다음 접근 방식을 사용하세요.

접근 방법 1(권장)

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

이 메소드는 selectRaw()를 사용합니다. 계산된 합계(sum)에 대한 별칭을 만드는 방법입니다. 그런 다음 pluck() 메소드는 sum 및 users_editor_id 필드를 추출하여 연관 배열 결과를 제공합니다.

접근법 2

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

이 메소드는 의사 ORM을 생성합니다. 각 문서 모델에 합계 필드를 추가하면 결과가 나타납니다. 하지만 그 결과가 진정한 ORM 컬렉션이 아니기 때문에 덜 바람직합니다.

위 내용은 Laravel Eloquent에서 GroupBy를 사용하여 합계를 올바르게 계산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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