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';
设置成功后就好了
想看更多精彩内容,可以关注我的博客园
我的博客园