Sql语句group by 异常问题 ONLY_FULL_GROUP_BY

本文探讨了在MySQL 5.7及以上版本中遇到的GROUP BY错误,由于sql_mode=‘ONLY_FULL_GROUP_BY’导致的查询非法。作者分享了解决方案,包括检查版本、调整sql_mode设置,以及应对策略以确保在不同环境下的SQL执行正确性。
摘要由CSDN通过智能技术生成

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

在这里插入图片描述
设置成功后就好了
在这里插入图片描述

想看更多精彩内容,可以关注我的博客园
我的博客园

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值