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

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

王雪芹
王雪芹원래의
2020-05-12 10:41:449562검색

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

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

버스 테이블: 예제를 통해 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으로 문의하세요.