mysql分组条件和查询结果不同,如何解决sql_mode=only_full_group_by?

sql:

//查询结果比分组多报错
 select  rong_liang,yong_liang,`level`,adapt_niandu,perrfect_niandu,
 oil_type,fadongji,GROUP_CONCAT(mid) as mids,mid
 from datum_copy3 WHERE rong_liang != "" and  rong_liang != 
 "电动车" and oil_type != "" and perrfect_niandu !=""
 AND `level` != "" AND  fadongji != ""
 group by rong_liang,yong_liang,`level`,adapt_niandu,
 perrfect_niandu,oil_type,fadongji;

sql提示: Expression #9 of SELECT list is not in GROUP BY clause and contains nonaggregated column ‘f6dos.datum_copy3.mid’ which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by, Time: 0.000000s

这肯定是mysql的sql_mode配置问题!
通过 sql查询默认的格式
select @@global.sql_mode
结果: 必须是所有分组条件,
在这里插入图片描述

解决

set @@global.sql_mode 
="STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION";

然而并没有成功!!!

又查了下

SELECT @@SESSION.sql_mode;

发现还有only_full_group_by。

重新设置@@SESSION.sql_mode的值去掉,only_full_group_by

set @@global.sql_mode 
="STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION";

完美解决:

总结:

-- 需要看两个属性
select @@global.sql_mode;
SELECT @@SESSION.sql_mode;
-- 如果都有only_full_group_by去掉即可
set @@SESSION.sql_mode
="STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION";
set @@global.sql_mode 
="STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION";
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值