MySql报错only_full_group_by的解决办法
2022/7/30 2:23:25
本文主要是介绍MySql报错only_full_group_by的解决办法,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
回到顶部问题
MySQL5.7以上版本,默认开启了only_full_group_by模式:
> select @@global.sql_mode; ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
开启这个模式后,不符合的group by语句就会报错:
SELECT list is not in GROUP BY clause and contains nonaggregated column 'test' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by
回到顶部
原因
MySQL在低版本(5.7.x以下)中允许select后面的非聚合列不出现在group by中。以下sql在低版本中是可以运行的,但是在5.7及以上版本会报错:
select name, age, count(name) from student group by age
order by后面的列必须是在select中存在。
select、having或order by后面存在的非聚合列必须全部在group by中存在。
而没有遵循原则的sql会被认为是不合法的sql,如SQLServer、Oracle、PostgreSql都不支持select target list中出现语义不明确的列,MySQL 5.7开始修正,即ONLY_FULL_GROUP_BY语义。
回到顶部
解决
方案一:保持only_full_group_by模式开启
MySQL提供了any_value(field)函数允许非分组字段的出现(和关闭 only_full_group_by 模式有相同效果)。
select any_value(name), age, count(name) from student group by age
方案二:关闭only_full_group_by模式
1)当前会话关闭失效
> select @@sql_mode
复制查询出来的值,去除only_full_group_by,再设置回去:
> set sql_mod='去除only_full_group_by后的值'
比如:在navicat中当前窗口执行,在当前窗口生效,新开窗口失效。
2)当前服务关闭失效
> select @@global.sql_mode
复制查询出来的值,去除only_full_group_by,再设置回去:
> set @@global.sql_mode='去除only_full_group_by后的值'
3)永久生效
修改MySQL配置文件my.conf,然后重启MySQL。
[mysqld] sql_mode=去除only_full_group_by后的值
4)JDBC参数关闭only_full_group_by
jdbc:mysql://localhost:3306/test?sessionVariables=sql_mode='去除only_full_group_by后的值'
这篇关于MySql报错only_full_group_by的解决办法的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-04部署MySQL集群项目实战:新手入门教程
- 2024-11-04如何部署MySQL集群资料:新手入门指南
- 2024-11-02MySQL集群项目实战:新手入门指南
- 2024-11-02初学者指南:部署MySQL集群资料
- 2024-11-01部署MySQL集群教程:新手入门指南
- 2024-11-01如何部署MySQL集群:新手入门教程
- 2024-11-01部署MySQL集群学习:新手入门教程
- 2024-11-01部署MySQL集群入门:新手必读指南
- 2024-10-23BinLog入门:新手必读的MySQL二进制日志指南
- 2024-10-23Binlog入门:MySQL数据库的日志管理指南