예제를 통해 ThinkPHP6 공동 테이블 집계 쿼리 설명
몇일 전 한 친구가 공동 테이블의 집계 쿼리에 대해 문의했습니다. 이 문제는 많은 초보자들이 다루기 어려울 수 있다고 생각되어 이제 공유해 드립니다.
두 개의 데이터 테이블이 있습니다:
버스 테이블:
사용자 테이블:
요구 사항: 버스에 탄 사람 수를 세세요
어떻게 구현하나요?
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제









