몇일 전 한 친구가 공동 테이블의 집계 쿼리에 대해 문의했습니다. 이 문제는 많은 초보자들이 다루기 어려울 수 있다고 생각되어 이제 공유해 드립니다.
두 개의 데이터 테이블이 있습니다:
버스 테이블:
사용자 테이블:
요구 사항: 버스에 탄 사람 수를 세세요
어떻게 구현하나요?
1단계: 테이블 조인
이 시나리오에서는 확실히 두 개의 데이터 테이블을 조인해야 합니다. 먼저 통계를 고려하지 마세요.
$data=Db::name('user')->alias('a')->join('bus b','a.user_id=b.user_id')->select()->toArray();
alias는 별칭이고, Join은 조인트 테이블의 데이터 테이블이고, 조인트 테이블 조건 a.user_id=b.user_id가 있어 두 데이터 테이블의 데이터를 가져올 수 있습니다.
2단계: 집계 쿼리
집계 쿼리를 수행하기 전에 공식 매뉴얼 튜토리얼을 살펴보겠습니다.
우리는 궁극적으로 통계량을 얻고 싶기 때문에 먼저 count() 메서드를 사용하기로 결정하고 쿼리 문을 수정합니다.
$data=Db::name('user')->alias('a')->field('count(b.user_id) AS c'')->join('bus b','a.user_id=b.user_id')->select()->toArray();
여기서 c는 별칭입니다.
user_id 필드를 기준으로 집계 쿼리를 수행해야 합니다. 통계는 이 필드를 기반으로 하므로 group(user_id), 즉 user_id 필드에 따라 그룹화되어야 합니다.
우리는 계속해서 쿼리 문을 수정합니다.
$data=Db::name('user')->alias('a')->field('count(b.user_id) AS c')->join('bus b','a.user_id=b.user_id')->group('a.user_id')->select()->toArray();
이러한 방식으로 최종 쿼리 결과를 얻습니다.
세 번째 사항: 상황에 주의하세요.
위 쿼리문에서 mysql이 5.7 버전이라면 특별한 주의가 필요합니다. 예를 들어 mysql5.7의 필드에 a.*를 추가하면 다음과 같은 오류가 보고됩니다.
$data=Db::name('user')->alias('a')->field('a.*,count(b.user_id) AS c')->join('bus b','a.user_id=b.user_id')->group('a.user_id')->select()->toArray(); [object Object]
왜 이런 오류가 발생합니까?
MYSQL5.7에는 더 나은 성능을 위해 sql_mode에 대한 제한이 있습니다.
ONLY_FULL_GROUP_BY: GROUP BY 집계 작업의 경우 SELECT의 열이 GROUP BY에 나타나지 않으면 해당 열이 오류가 보고되는 GROUP BY 절에 없기 때문에 이 SQL은 불법입니다.
mysql 구성을 수정할 수 있습니다:
/etc/my.cnf를 수정하고 sql_mode=
에서 only_full_group_by를 삭제하세요. 이러한 방식으로 공동 테이블의 집계 쿼리가 실현됩니다. 조급해하지 말고 단계별로 나누어 최종 필요에 따라 단계별로 구현하세요.
위 내용은 예제를 통해 ThinkPHP6 공동 테이블 집계 쿼리 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!