在开发过程中,经常会遇到分组查询
那么我们在使用
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 以前的版本的效果了
修改配置文件的方式这里就不写了,网上有很多方式, 个人还是建议不管是学习还是工作都尽量不要去使用修改配置文件的方式, 一般公司是不会让你修改配置文件的, 即使允许你修改开发环境的,但是生产环境一般情况下不会让你修改, 就会造成在开发环境下没问题, 但到了生产环境就挂了的情况。所以尽量在不修改默认配置文件的情况下解决问题