MySQL5.7以上使用分组1055报错问题

在开发过程中,经常会遇到分组查询
那么我们在使用

SELECT * FROM table GROUP BY column

有用过MySQL5.6以前的版本的同学, 应该就知道, 在5.6以前这条语句是不会报错的, 他会查询出分组后的第一条数据, 有时候我们有些需求又刚好是这样子

造成这个问题的原因是: 因为从MySQL5.7开始,MySQL开始使用严格模式
执行同样的语句时,MySQL5.7以上的版本就会报1055的错误

1055 - Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column ‘table.id’ which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

解决方式
在真实开发过程中, 一般情况下是不允许个人去修改配置文件, 所以这里个人不推荐修改配置文件
可以从SQL入手解决, 只需要在相关字段上添加 any_value() 函数就可以解决
如:

SELECT 
	any_value(id) AS id,
	any_value(name) AS name,
	any_value(age) AS age,
	any_value(email) AS email
FROM
	`user`
GROUP BY
 	name

这样子就可以达到跟 MySQL5.6 以前的版本的效果了

修改配置文件的方式这里就不写了,网上有很多方式, 个人还是建议不管是学习还是工作都尽量不要去使用修改配置文件的方式, 一般公司是不会让你修改配置文件的, 即使允许你修改开发环境的,但是生产环境一般情况下不会让你修改, 就会造成在开发环境下没问题, 但到了生产环境就挂了的情况。所以尽量在不修改默认配置文件的情况下解决问题

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值