mysql full group by_MySql报错only_full_group_by的解决办法
前段时间我在一个新环境里部署程序时遇到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的解决办法相关推荐
- mysql1055_MySQL5.7 group by新特性报错1055的解决办法
项目中本来使用的是mysql5.6进行开发,切换到5.7之后,突然发现原来的一些sql运行都报错,错误编码1055,错误信息和sql_mode中的"only_full_group_by&qu ...
- linux mysql 登录报1045_【mysql】linux登录MySQL_报错ERROR_1045_(28000)解决办法
[mysql]linux登录MySQL_报错ERROR_1045_(28000)解决办法 5年前 (2015-09-17) 作者:Jiaozn 分类:MySQL 阅读次数:1852 ...
- pom.xml内容没有错,但一直报错红叉 解决办法
转自:http://www.cnblogs.com/sxdcgaq8080/p/5590254.html [maven] pom.xml内容没有错,但一直报错红叉 解决办法 1.首先看一下下面的这两个 ...
- CFX计算报错和相应解决办法(浮点错误等-持续更新)
CFX计算报错和相应解决办法(浮点错误等-持续更新) 1.CFX浮点错误 Floating point exception:Overflow 数值计算过大,浮点数位数不够,使用双精度double类型计 ...
- python modulenotfounderror_python 服务器运行代码报错ModuleNotFoundError的解决办法
一.问题描述 一段 Python 代码在本地的 IDE 上运行正常,部署到服务器运行后,出现了 ModuleNotFoundError: No module named 'xxx" 错误. ...
- IndexError: list index out of range--Python报错原因及解决办法
报错原因 一.括号里面的索引index超出范围 例如:要查找最后一个明星的名字'Hannah Quinlivan',Index输入为4.在Python中,第四个元素的索引为3,因为索引是从0开始的.如 ...
- oracle lms进程 内存,【案例】Oracle ges resource消耗内存高报错ORA-04031 MOS解决办法...
天萃荷净 Oracle研究中心案例分析:运维DBA反映Oracle数据库10.2.0.4.12每间隔一段时间就必须重启,运行一断时间报ORA-04031错误oracle ges res cache l ...
- 面对CUDA报错的种种解决办法
面对CUDA报错的种种解决办法 1 cuda failure 4 1 cuda failure 4 检查是否被docker容器所挂载完?
- mysql grant reload,MySQL执行GRANT命令时报错ERROR 1045解决办法
摘要 腾兴网为您分享:MySQL执行GRANT命令时报错ERROR 1045解决办法,杂志迷,云闪付,一直播,小象优品等软件知识,以及592美剧,乐天网络电视,吃鸡无后座,易语言宝盒,语音转文字软件, ...
最新文章
- 使用Caffe预测遇到的问题
- linux 怎么把^M去掉
- java字符串包含连续数字,Java中包含数字的排序字符串
- ActiveX控件在项目中的应用
- 2.OAuth 简介(2)
- Stm32 固件库移植
- matlab中四元数与三维向量的乘,四元数与三维向量相乘运算法则
- 查看浏览器占有的市场份额
- 【转发分享】基于51单片机摩尔斯电码收发控制设计-基于51单片机智能恒温控制系统-基于51单片机霍尔测速直流电机设计-51单片机和MAX1898的智能手机充电器设计-基于51单片机的智能指纹考勤系统
- 本地机房连接阿里云专有网络VPC构建混合云解决方案
- Java画布:直线三角形,矩形,椭圆等
- ubuntu不支持安装搜狗_Ubuntu系统安装搜狗输入法详细教程
- 累加一到50python_numpy累加方法介绍
- ADG - Active
- CAD自动绘图如何实现钣金折弯开角与面板厚度算法
- java猜生日代码_生日日数 (Java代码)
- 十大热招城市公布,上海依然是跳槽首选
- delphi txt文件读写
- TPS2552DBVR精密可调节限流配电开关TI
- 圆锥曲线的部分趣事——圆的第二定义的传统几何证明方法、过圆锥曲线上点的切线方程以及该方程更广泛的意义
热门文章
- C++STL的string容器
- c++ 类和类的定义
- 22 Python IO、打印到屏幕、读取键盘输入、打开和关闭文件、文件定位、重命名和删除文件、Python里的目录、文件,目录相关的方法
- uploadify在火狐下上传不了的解决方案,java版(Spring+SpringMVC+MyBatis)详细解决方案
- 线性代数之矩阵逆的微分
- 表的插入、更新、删除、合并操作_10_仅复制表结构
- Java结合POI清洗Excel
- SDRAM工作的大体流程
- C++类的基本学习知识
- jQuery.parseJSON()函数详解