在开发中遇到正式环境下使用mql分组查询语句,报错,测试环境下正常,究其原因是mql版本不同导致。
在MySQL 5.7后,MySQL默认开启了SQL_MODE严格模式,对数据进行严格校验。如果代码中含有group by聚合操作,那么select中的列,除了使用聚合函数之外的,如max()、min()等,都必须出现在group by中。
比如说,出现下面这种情况,就会报错:
select Beijing,Shanghai from city group by Beijing
如果改成这个样子:
select Beijing,Shanghai from city group by Beijing,Shanghai
或者这个样子:
select Beijing from city group by Beijing
就不会报错了。
当然,这样子随意的改动代码,我们可能就无法得到想要的信息了。
我们可以通过以下四种方法,解决该问题:
具体的参考其他友军的
https://blog.csdn.net/qq118640594X/article/details/128024350
本次我的错误语句是:
select bd.`Label` Name,COUNT(c.Id) Total
from base_companyinfo c
left join base_dict_details bd on c.Industry=bd.`Value`
GROUP BY c.Industry
修改后的语句
select group_concat(bd.`Label`) Name,COUNT(c.Id) Total
from base_companyinfo c
left join base_dict_details bd on c.Industry=bd.`Value`
GROUP BY c.Industry