從實例講解ThinkPHP6聯(lián)表聚合查詢

前些天有朋友問到了一個聯(lián)表的聚合查詢問題,想到此問題可能很多新手處理都比較棘手,現(xiàn)在特意分享出來。

我們有兩個數(shù)據(jù)表:

bus表:從實例講解ThinkPHP6聯(lián)表聚合查詢

user表:

從實例講解ThinkPHP6聯(lián)表聚合查詢

立即學(xué)習(xí)PHP免費學(xué)習(xí)筆記(深入)”;

需求:統(tǒng)計每個人上車數(shù)量

如何實現(xiàn)呢?

第一步:聯(lián)表

這種場景肯定需要兩個數(shù)據(jù)表聯(lián)表,我們先不考慮統(tǒng)計,我們先進(jìn)行兩個數(shù)據(jù)表聯(lián)表。

?$data=Db::name('user')->alias('a')->join('bus?b','a.user_id=b.user_id')->select()->toArray();

alias是別名,join是聯(lián)表的數(shù)據(jù)表,并且有聯(lián)表條件a.user_id=b.user_id,這樣我們就能夠獲取到兩個數(shù)據(jù)表聯(lián)表的數(shù)據(jù)了。

從實例講解ThinkPHP6聯(lián)表聚合查詢

第二步:聚合查詢

在做聚合查詢前,我們先看下官方手冊的教程。

從實例講解ThinkPHP6聯(lián)表聚合查詢

因為我們最終是要獲取統(tǒng)計的數(shù)量,所以我們首先確定用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,是別名。

我們需要根據(jù)user_id這個字段進(jìn)行聚合查詢,是根據(jù)這個字段統(tǒng)計的,所以我們肯定是group(user_id),也就是按照user_id這個字段進(jìn)行分組。

我們繼續(xù)修改查詢語句:

$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();

這樣我們就實現(xiàn)了我們的最終查詢結(jié)果。

第三點:注意情況

在上面的查詢語句中,如果mysql是5.7版本,那么需要格外注意。比如在mysql5.7中在field中添加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聯(lián)表聚合查詢

MYSQL5.7為了更好的性能,對sql_mode的限制。

ONLY_FULL_GROUP_BY: 對于GROUP BY聚合操作的時候,如果在SELECT中的列,沒有在GROUP BY中出現(xiàn),那么這個SQL是不合法的,因為列不在GROUP BY從句中,這也就是報錯所在。

我們可以修改mysql配置:

修改/etc/my.cnf,將sql_mode=中的only_full_group_by給刪掉

這樣一個聯(lián)表的聚合查詢就實現(xiàn)了,我們遇到這個問題的時候,不要心急,根據(jù)最終的需求,一步步的拆分一步步的實現(xiàn)。

? 版權(quán)聲明
THE END
喜歡就支持一下吧
點贊14 分享