您当前的位置:首页 > 计算机 > 软件应用 > 数据库 > MySQL

MySQL提示sql_mode=only_full_group_by解决办法

时间:08-18来源:作者:点击数:
CDSY,CDSY.XYZ

MySQL异常sql_mode=only_full_group_by

原因:在MySQL 5.7后MySQL默认开启了SQL_MODE严格模式,对数据进行严格校验。

会报sql_mode=only_full_group_by错误说明写的SQL语句不严谨,

对于group by聚合操作,select中的列只能是出现在group by中的列,使用聚合函数除外,如max()、min()等

如以下例子会报错:

select id, no, uid from user_order group by uid;

改成下面的SQL则不报错:

select uid from user_order group by uid;

解决这个问题可以有三个方法:

方法一:

使用 group_concat() 或 any_value()

group_concat():将分到同一组的数据默认用逗号隔开作为返回数据

any_value():将分到同一组的数据里第一条数据的指定列值作为返回数据

修改后语句如下:

select GROUP_CONCAT(id), GROUP_CONCAT(no), uid from user_order group by uid;
select any_value(id), any_value(no), uid from user_order group by uid;

方法二:

如果语句太多,变动太大,可以改数据库配置

首先查看当前sql_mode

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

重新设置,去掉ONLY_FULL_GROUP_BY即可:

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';

当然,如果想去掉所有限制也是可以的:

SET GLOBAL sql_mode='';

这个方法的好处是不用重启MySQL生效(需要注意的是在当前会话实例中是不生效的),坏处是重启后会恢复原样。

方法三:

永久生效,修改配置文件my.ini

在[mysqld]模块下新增一行配置:

sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'

保存,重启后生效。

CDSY,CDSY.XYZ
方便获取更多学习、工作、生活信息请关注本站微信公众号城东书院 微信服务号城东书院 微信订阅号
推荐内容
相关内容
栏目更新
栏目热门
本栏推荐