Sql语句group by 异常问题 ONLY_FULL_GROUP_BY

今天将项目部署到在服务器上测试,调用一个接口 关于 执行的SQL语句包含 group by ,然后报错。

本以为是第一次使用,不会用jpa的锅,后来自己部署到自己的Linux上测试发现是下面的错误。

mysql 5.7 版本及以上版本会出现的问题:
mysql 5.7版本默认的sql配置是:sql_mode="ONLY_FULL_GROUP_BY",这个配置严格执行了"SQL92标准"。

在sql执行时,输出的结果是叫target list(即select后面跟着的字段),还有一个地方group by column(group by后面跟着的字段)。由于开启了ONLY_FULL_GROUP_BY的设置,所以如果一个字段没有在target list和group by字段中同时出现,或者是聚合函数的值的话,那么这条sql查询是被mysql认为非法的,会报错误。

如何解决?

##查看mysql版本命令
select version();

我的是5.5.40不会出现这个问题,这就导致了我在本地测试的时候不会出错,但是服务器上的mysql是5.7以上,我没有那个环境我就不那个截图了。

##查看sql_model参数命令: 
SELECT @@SESSION.sql_mode;
##@@SESSION.sql_mode只是查看当前连接,全看全局的用下面的命令
SELECT @@global.sql_mode

  

##关闭ONLY_FULL_GROUP_BY(其实就是设置sql_model):
  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';
##当前设置的只是当前连接的,要设置全局的(global)就得执行下面这条语句
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';

设置成功后就好了

 

想看更多精彩内容,可以关注我的CSDN

我的CSDN

posted @ 2021-03-26 08:38  Yblue  阅读(68)  评论(0编辑  收藏  举报