首页 > 数据库 >mysql 数据从5.6版迁移到5.7以后版的数据(包括8.0) 提示sql_mode=only_full_group_by解决办法

mysql 数据从5.6版迁移到5.7以后版的数据(包括8.0) 提示sql_mode=only_full_group_by解决办法

时间:2022-10-16 22:38:02浏览次数:90  
标签:group 5.6 NO 5.7 ZERO mode sql GROUP


SQLSTATE[42000]: Syntax error or access violation: 1055 Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'sid.xid' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

一、原理层面

       这个错误发生在mysql 5.7 版本及以上版本会出现的问题:

       mysql 5.7版本默认的sql配置是:sql_mode="ONLY_FULL_GROUP_BY",这个配置严格执行了"SQL92标准"。

       很多从5.6升级到5.7时,为了语法兼容,大部分都会选择调整sql_mode,使其保持跟5.6一致,为了尽量兼容程序。

二、sql层面

        在sql执行时,出现该原因:

        简单来说就是:输出的结果是叫target list,就是select后面跟着的字段,还有一个地方group by column,就是

        group by后面跟着的字段。由于开启了ONLY_FULL_GROUP_BY的设置,所以如果一个字段没有在target list 

        和group by字段中同时出现,或者是聚合函数的值的话,那么这条sql查询是被mysql认为非法的,会报错误。

对于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;

解决办法:

mysql 5.7数据库模式改成非严格校验模式

第一种方法:数据库自建数据库,和ECS同一台服务器

方法一:
使用 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'


保存,重启后生效。

第二种方法:阿里RDS数据库

登录阿里RDS数据库在这里修改 

mysql 数据从5.6版迁移到5.7以后版的数据(包括8.0) 提示sql_mode=only_full_group_by解决办法_数据库

参考:

​MySQL提示sql_mode=only_full_group_by解决办法​

​解决报错:SQLSTATE[42000]: Syntax error or access violation: 1055 Expression #1 of SELECT list is not in GROUP的终结办法-ERP-CRM-OA-MES-WMS-协同办公软件开发定制-山西木子天禾网络科技有限公司​



标签:group,5.6,NO,5.7,ZERO,mode,sql,GROUP
From: https://blog.51cto.com/haibo0668/5760728

相关文章