mysql 新版本出现group by 语句不兼容问题

本文介绍了解决MySQL 5.7.x版本中因启用only_full_group_by模式而导致的错误方法。通过修改sql_mode设置或使用any_value()函数,解决了group by语句的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原文地址:http://www.cnblogs.com/anstoner/p/6414440.html


注:文中的方式,我只是用了修改sql mode 的方法,其它的未尝试,全文如下:



下载安装的是最新版的mysql5.7.x版本,默认是开启了 only_full_group_by 模式的,但开启这个模式后,原先的 group by 语句就报错,然后又把它移除了。

一旦开启 only_full_group_by ,感觉,group by 将变成和 distinct 一样,只能获取受到其影响的字段信息,无法和其他未受其影响的字段共存,这样,group by 的功能将变得十分狭窄了

only_full_group_by 模式开启比较好。

因为在 mysql 中有一个函数: any_value(field) 允许,非分组字段的出现(和关闭 only_full_group_by 模式有相同效果)。

 

1. 具体出错提示:

[Err] 1055 - Expression #1 of ORDER BY clause is not in GROUP BY clause and contains nonaggregated column 'information_schema.PROFILING.SEQ' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

1.1. 1、查看sql_mode

01
select @@global.sql_mode;

1.2. 查询出来的值为:

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

2. 2、去掉ONLY_FULL_GROUP_BY,重新设置值。

01
set @@global.sql_mode ='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';

2.1. 3、上面是改变了全局sql_mode,对于新建的数据库有效。对于已存在的数据库,则需要在对应的数据下执行:

1
set sql_mode ='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';

  

3. 解决办法大致有两种:

一:在sql查询语句中不需要group by的字段上使用any_value()函数

这种对于已经开发了不少功能的项目不太合适,毕竟要把原来的sql都给修改一遍

3.1. 二:修改my.cnf(windows下是my.ini)配置文件,删掉only_full_group_by这一项

若我们项目的mysql安装在ubuntu上面,找到这个文件打开一看,里面并没有sql_mode这一配置项,想删都没得删。

当然,还有别的办法,打开mysql命令行,执行命令

1
select @@sql_mode;

这样就可以查出sql_mode的值,复制这个值,在my.cnf中添加配置项(把查询到的值删掉only_full_group_by这个选项,其他的都复制过去):

1
sql_mode=STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION;

如果 [mysqld] 这行被注释掉的话记得要打开注释。然后重重启mysql服务

注:使用命令

1
set sql_mode=STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

这样可以修改一个会话中的配置项,在其他会话中是不生效的。  

 

### 关于 MySQL 中 `GROUP BY` 的配置与使用 在 MySQL 9.0 版本中,虽然官方尚未发布此版本,但从现有资料可以推测其特性会继承自较新版本8.0 或者更高。对于 `ONLY_FULL_GROUP_BY` SQL 模式的处理方式,在执行带有 `GROUP BY` 子句的查询语句时变得更为严格[^3]。 当启用 `ONLY_FULL_GROUP_BY` 参数后,如果尝试在一个 `SELECT` 列表中的表达式既不在聚合函数内也不位于 `GROUP BY` 子句里,则会产生错误提示。这是因为该设置强制要求所有选定列要么被包含在 `GROUP BY` 后面指定的一组字段之中,要么作为聚集操作的一部分出现[^4]。 为了正确地应用 `GROUP BY` 并避免上述提到的错误情况发生: #### 修改全局变量 `sql_mode` 可以通过调整服务器级别的参数来改变默认行为。具体做法是从当前生效模式列表里面移除 `ONLY_FULL_GROUP_BY`: ```sql SET GLOBAL sql_mode=(SELECT REPLACE(@@sql_mode,'ONLY_FULL_GROUP_BY','')); ``` 但是需要注意的是这种修改可能会影响到整个数据库实例上的其他应用程序逻辑;因此更推荐的做法是在创建连接的时候临时更改 session 层面上的 mode 设置: ```sql SET SESSION sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'; ``` #### 调整查询结构 另一种方法就是重构原始SQL请求使其满足新的语法规定——即确保所有的非汇总项都出现在 `GROUP BY` 部分之内。例如原先是这样的写法导致报错: ```sql select * from emp group by post; ``` 那么应该改为只选取那些真正用于分组统计计算所需的属性加上必要的聚合运算结果: ```sql SELECT post, COUNT(*), AVG(salary) FROM emp GROUP BY post; ``` 这样不仅解决了兼容性问题还提高了查询效率并增强了可读性和维护便利度。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值