ThinkPHP6联表聚合查询的示例

  介绍

这篇文章将为大家详细讲解有关ThinkPHP6联表聚合查询的示例,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

我们有两个数据表:

<强>公车表:  ThinkPHP6联表聚合查询的示例

<强>用户表:

<强>  ThinkPHP6联表聚合查询的示例

<强>需求:统计每个人上车数量

如何实现呢?

<强>第一步:联表

这种场景肯定需要两个数据表联表,我们先不考虑统计,我们先进行两个数据表联表。

,$ data=https://www.yisu.com/zixun/Db:名称(“用户”)->别名(a) ->加入(b总线,a.user_id=b.user_id) ->选择()-> toArray ();

别名是别名,加入是联表的数据表,并且有联表条件a.user_id=b。user_id,这样我们就能够获取到两个数据表联表的数据了。

 ThinkPHP6联表聚合查询的示例

<强>第二步:聚合查询

在做聚合查询前,我们先看下官方手册的教程。

 ThinkPHP6联表聚合查询的示例

因为我们最终是要获取统计的数量,所以我们首先确定用计数()方法,所以我们修改查询语句:

$ data=https://www.yisu.com/zixun/Db::名称(“用户”)->别名(a) ->字段('计数(b.user_id) c”) ->加入(b总线,a.user_id=b.user_id) ->选择()-> toArray ();

这其中c,是别名。

我们需要根据user_id这个字段进行聚合查询,是根据这个字段统计的,所以我们肯定是集团(user_id),也就是按照user_id这个字段进行分组。

我们继续修改查询语句:

$ data=https://www.yisu.com/zixun/Db::名称(“用户”)->别名(a) ->字段(计数(b.user_id) c) ->加入(b总线,a.user_id=b.user_id) ->集团(“a.user_id”) ->选择()-> toArray ();

这样我们就实现了我们的最终查询结果。

<强>第三点:注意情况

在上面的查询语句中,如果mysql 5.7版是本,那么需要格外注意。比如在mysql5.7中在字段中添加。*,就会报错:

,$ data=https://www.yisu.com/zixun/Db:名称(“用户”)->别名(a) ->字段(”。*,计数(b.user_id) c”) ->加入(b总线,a.user_id=b.user_id) ->集团(“a.user_id”) ->选择()-> toArray ();   [对象对象]

为什么会有这样的错误呢?

 ThinkPHP6联表聚合查询的示例

MYSQL5.7为了更好的性能,对sql_mode的限制。

ONLY_FULL_GROUP_BY:对于GROUP BY聚合操作的时候,如果在选择中的列,没有在集团中出现,那么这个SQL是不合法的,因为列不在GROUP BY从句中,这也就是报错所在。

<强>我们可以修改mysql配置:

修改,/etc/my . cnf中所做将sql_mode=中的ONLY_FULL_GROUP_BY给删掉

这样一个联表的聚合查询就实现了,我们遇到这个问题的时候,不要心急,根据最终的需求,一步步的拆分一步步的实现。

关于“ThinkPHP6联表聚合查询的示例”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看的到。

ThinkPHP6联表聚合查询的示例