PHP 프레임워크 ThinkPHP 예제를 통해 ThinkPHP6 공동 테이블 집계 쿼리 설명

예제를 통해 ThinkPHP6 공동 테이블 집계 쿼리 설명

May 12, 2020 am 10:41 AM
thinkphp6

몇일 전 한 친구가 공동 테이블의 집계 쿼리에 대해 문의했습니다. 이 문제는 많은 초보자들이 다루기 어려울 수 있다고 생각되어 이제 공유해 드립니다.

두 개의 데이터 테이블이 있습니다:

버스 테이블: 예제를 통해 ThinkPHP6 공동 테이블 집계 쿼리 설명

사용자 테이블:

예제를 통해 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가 있어 두 데이터 테이블의 데이터를 가져올 수 있습니다.

예제를 통해 ThinkPHP6 공동 테이블 집계 쿼리 설명

2단계: 집계 쿼리

집계 쿼리를 수행하기 전에 공식 매뉴얼 튜토리얼을 살펴보겠습니다.

예제를 통해 ThinkPHP6 공동 테이블 집계 쿼리 설명

우리는 궁극적으로 통계량을 얻고 싶기 때문에 먼저 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]
로그인 후 복사

왜 이런 오류가 발생합니까?

예제를 통해 ThinkPHP6 공동 테이블 집계 쿼리 설명

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

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

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

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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