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