完美解决mysql5.7以上版本 this is incompatible with sql_mode=only_full_group_by错误

ONLY_FULL_GROUP_BY是MySQL提供的一个sql_mode,通过这个sql_mode来提供SQL语句GROUP BY合法性的检查,在MySQL的sql_mode是非ONLY_FULL_GROUP_BY语义时。一条select语句,MySQL允许target list中输出的表达式是除聚集函数或group by column以外的表达式,这个表达式的值可能在经过group by操作后变成undefined,从而导致程序报错。

进入mysql服务后查看:

select @@global.sql_mode;

下面是完美解决的方案

找到my.conf文件,分别在[mysqld]和[mysql]下面添加这段 sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

然后重启mysql服务,问题解决。

当你再次进入mysql查看的时候,就会看到少了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';

但是执行完这个语句,再次select的时候还会有ONLY_FULL_GROUP_BY,不能够解决问题。over

发布了20 篇原创文章 · 获赞 22 · 访问量 4万+

猜你喜欢

转载自blog.csdn.net/yanzi920403/article/details/89207919