前段时间我在一个新环境里部署程序时遇到MySql报错only_full_group_by,之前已经遇到过一次同样的问题,当时没有总结经验,导致这次解决时耗费了不少时间,这里把本次的处理过程进行记录总结,同时分享给大家

MySql数据库报错如下,从字面意思理解是select后面查询的字段没有出现在group by中

com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException:

Expression #2 of SELECT list is not in GROUP BY clause and

contains nonaggregated column 'testdb.pot.username' which

is not functionally dependent on columns in GROUP BY clause;

this is incompatible with sql_mode=only_full_group_by

MySql在低版本(5.7.x以下)中允许select后面的非聚合列不出现在group by中。以下sql在低版本中是可以运行的,但是在5.7及以上版本会报错

-- 注意deptid没有出现在group by中

select t.deptid,t.class,count(1) from t_user t group by class;

MySql从5.7版本开始默认开启only_full_group_by规则,规则核心原则如下,没有遵循原则的sql会被认为是不合法的sql

1. order by后面的列必须是在select后面存在的

2. select、having或order by后面存在的非聚合列必须全部在group by中存在

问题解决

可以通过三种方式解决报错问题

第一种,修改sql使其遵守only_full_group_by规则

第二种,将MySql的版本降到5.7以下

第三种,关闭only_full_group_by规则

第一种方式适用于sql比较少的情况,如果程序中有大量的sql没有遵循only_full_group_by规则,这种方式修改起来会很浪费时间

第二种方式不建议使用,高版本很明显的一个好处是安全性高,如果降低版本会有一定的风险。

第三种方式比较推荐,不过要重启数据库,步骤如下

1. 查看是否开启了only_full_group_by规则校验,在数据库中执行如下sql

SELECT @@GLOBAL.sql_mode;

SELECT @@SESSION.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

2. 关闭only_full_group_by的规则校验,关闭规则校验需要执行如下sql。以下两个sql单引号中的内容是第一步查询的结果去掉“,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 @@SESSION.sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO, NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';

3. 重启数据库,登录数据库所在的服务器执行如下命令

service mysqld start;

微信搜索赫连小伍关注我的公众号,文章不定期推送

mysql full group by_MySql报错only_full_group_by的解决办法相关推荐

  1. mysql1055_MySQL5.7 group by新特性报错1055的解决办法

    项目中本来使用的是mysql5.6进行开发,切换到5.7之后,突然发现原来的一些sql运行都报错,错误编码1055,错误信息和sql_mode中的"only_full_group_by&qu ...

  2. linux mysql 登录报1045_【mysql】linux登录MySQL_报错ERROR_1045_(28000)解决办法

    [mysql]linux登录MySQL_报错ERROR_1045_(28000)解决办法 5年前 (2015-09-17)    作者:Jiaozn    分类:MySQL    阅读次数:1852 ...

  3. pom.xml内容没有错,但一直报错红叉 解决办法

    转自:http://www.cnblogs.com/sxdcgaq8080/p/5590254.html [maven] pom.xml内容没有错,但一直报错红叉 解决办法 1.首先看一下下面的这两个 ...

  4. CFX计算报错和相应解决办法(浮点错误等-持续更新)

    CFX计算报错和相应解决办法(浮点错误等-持续更新) 1.CFX浮点错误 Floating point exception:Overflow 数值计算过大,浮点数位数不够,使用双精度double类型计 ...

  5. python modulenotfounderror_python 服务器运行代码报错ModuleNotFoundError的解决办法

    一.问题描述 一段 Python 代码在本地的 IDE 上运行正常,部署到服务器运行后,出现了 ModuleNotFoundError: No module named 'xxx" 错误. ...

  6. IndexError: list index out of range--Python报错原因及解决办法

    报错原因 一.括号里面的索引index超出范围 例如:要查找最后一个明星的名字'Hannah Quinlivan',Index输入为4.在Python中,第四个元素的索引为3,因为索引是从0开始的.如 ...

  7. oracle lms进程 内存,【案例】Oracle ges resource消耗内存高报错ORA-04031 MOS解决办法...

    天萃荷净 Oracle研究中心案例分析:运维DBA反映Oracle数据库10.2.0.4.12每间隔一段时间就必须重启,运行一断时间报ORA-04031错误oracle ges res cache l ...

  8. 面对CUDA报错的种种解决办法

    面对CUDA报错的种种解决办法 1 cuda failure 4 1 cuda failure 4 检查是否被docker容器所挂载完?

  9. mysql grant reload,MySQL执行GRANT命令时报错ERROR 1045解决办法

    摘要 腾兴网为您分享:MySQL执行GRANT命令时报错ERROR 1045解决办法,杂志迷,云闪付,一直播,小象优品等软件知识,以及592美剧,乐天网络电视,吃鸡无后座,易语言宝盒,语音转文字软件, ...

最新文章

  1. 使用Caffe预测遇到的问题
  2. linux 怎么把^M去掉
  3. java字符串包含连续数字,Java中包含数字的排序字符串
  4. ActiveX控件在项目中的应用
  5. 2.OAuth 简介(2)
  6. Stm32 固件库移植
  7. matlab中四元数与三维向量的乘,四元数与三维向量相乘运算法则
  8. 查看浏览器占有的市场份额
  9. 【转发分享】基于51单片机摩尔斯电码收发控制设计-基于51单片机智能恒温控制系统-基于51单片机霍尔测速直流电机设计-51单片机和MAX1898的智能手机充电器设计-基于51单片机的智能指纹考勤系统
  10. 本地机房连接阿里云专有网络VPC构建混合云解决方案
  11. Java画布:直线三角形,矩形,椭圆等
  12. ubuntu不支持安装搜狗_Ubuntu系统安装搜狗输入法详细教程
  13. 累加一到50python_numpy累加方法介绍
  14. ADG - Active
  15. CAD自动绘图如何实现钣金折弯开角与面板厚度算法
  16. java猜生日代码_生日日数 (Java代码)
  17. 十大热招城市公布,上海依然是跳槽首选
  18. delphi txt文件读写
  19. TPS2552DBVR精密可调节限流配电开关TI
  20. 圆锥曲线的部分趣事——圆的第二定义的传统几何证明方法、过圆锥曲线上点的切线方程以及该方程更广泛的意义

热门文章

  1. C++STL的string容器
  2. c++ 类和类的定义
  3. 22 Python IO、打印到屏幕、读取键盘输入、打开和关闭文件、文件定位、重命名和删除文件、Python里的目录、文件,目录相关的方法
  4. uploadify在火狐下上传不了的解决方案,java版(Spring+SpringMVC+MyBatis)详细解决方案
  5. 线性代数之矩阵逆的微分
  6. 表的插入、更新、删除、合并操作_10_仅复制表结构
  7. Java结合POI清洗Excel
  8. SDRAM工作的大体流程
  9. C++类的基本学习知识
  10. jQuery.parseJSON()函数详解