这篇文章将为大家详细讲解有关ThinkPHP6联表聚合查询的示例,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
创新互联建站专注于企业全网营销推广、网站重做改版、望都网站定制设计、自适应品牌网站建设、H5响应式网站、商城网站建设、集团公司官网建设、外贸网站制作、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为望都等各大城市提供网站开发制作服务。我们有两个数据表:
bus表:
user表:
需求:统计每个人上车数量
如何实现呢?
第一步:联表
这种场景肯定需要两个数据表联表,我们先不考虑统计,我们先进行两个数据表联表。
$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,这样我们就能够获取到两个数据表联表的数据了。
第二步:聚合查询
在做聚合查询前,我们先看下官方手册的教程。
因为我们最终是要获取统计的数量,所以我们首先确定用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中在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]
为什么会有这样的错误呢?
MYSQL5.7为了更好的性能,对sql_mode的限制。
ONLY_FULL_GROUP_BY: 对于GROUP BY聚合操作的时候,如果在SELECT中的列,没有在GROUP BY中出现,那么这个SQL是不合法的,因为列不在GROUP BY从句中,这也就是报错所在。
我们可以修改mysql配置:
修改/etc/my.cnf,将sql_mode=中的only_full_group_by给删掉
这样一个联表的聚合查询就实现了,我们遇到这个问题的时候,不要心急,根据最终的需求,一步步的拆分一步步的实现。
关于“ThinkPHP6联表聚合查询的示例”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
分享标题:ThinkPHP6联表聚合查询的示例-创新互联
本文来源:http://lswzjz.com/article/ccsgid.html