In aggregated query without GROUP BY, expression #2 of SELECT list contains nonaggregated column...
ERROR 1140 (42000): In aggregated query without GROUP BY, expression #1 of SELECT list contains nonaggregated column ‘mydb.student.sname’; this is incompatible with sql_mode=only_full_group_by
maven项目报错error:
expression #2 of SELECT list contains nonaggregated column ‘newhelp.appr.title’; this is incompatible with sql_mode=only_full_group_by
这是因为随着MySQL版本更新带来的问题,在MySQL5.7版本之后对group by进行了优化。他默认启动改进之后的
版本启动了ONLY_FULL_GROUP_BY模式。
这种模式的官方解释:ONLY_FULL_GROUP_BY是MySQL数据库提供的一个sql_mode,通过这个sql_mode来保证
SQL语句“分组求最值”合法性的检查。这种模式采用了与Oracle、DB2等数据库的处理方式。即不允许select target list
中出现语义不明确的列。
通俗的讲就是:对于用到GROUP BY的select语句,查出来的列必须是group by后面声明的列,或者是聚合函数里面的列
有这样一个数据库的表
select语句:select id, sum(appr_id) from appr group by id------------------------------------(合法)
select语句:select id, user_id, sum(appr_id) from appr group by id-------------------------(合法)
select语句:select id, sum(appr_id) from appr group by role----------------------------------(不合法)
select语句:select id, user_id, sum(appr_id) from appr group by role-----------------------(不合法)
select语句:select * from appr group by role-------------------------------------------------------(不合法)
经过大量测试:笔者发现了ONLY_FULL_GROUP_BY这种模式的特点:
1:只要有聚合函数sum(),count(),max(),avg()等函数就需要用到group by,否则就会报上面的错误。
2:group by id(id是主键)的时候,select什么都没有问题,包括有聚合函数。
3:group by role(非主键)的时候,select只能是聚合函数和role(group by的字段),否则报错
如果我们不想用用ONLY_FULL_GROUP_BY的模式。有两种解决这种问题的方案:
1:命令行中输入:
set @@GLOBAL.sql_mode=’’;
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’;
不过这种情况治标不治本,一旦mysql重启之后又会恢复。
2:修改MySQL的配置文件,
1、windows下找到MySQL的安装目录的my.ini文件,修改其中的配置为不启动ONLY_FULL_GROUP_BY模式
删掉带有ONLY_FULL_GROUP_BY的模式就ok了,如果没有找到my.ini文件。
去系统的隐藏文件夹查看,在某个盘下输入%ProgramData%然后搜索MySQL的my.ini文件
2、linux下找到my.cnf文件,这个是配置MySQL的文件。一般这个文件是在etc文件夹下。
vi my.cnf 编辑这个文件,然后在图示的位置上加入sql_mode =
"STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION,NO_ZERO_DATE,NO_ZERO_IN_DATE,ERROR_FO
R_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER"
然后重启MySQL服务:service mysqld restart
注意:服务重启之后不一定立即生效,尤其是你买的服务器,存在延时。所以可能等一两个小时才生效。
goodluck!
————————————————
版权声明:本文为CSDN博主「不坠青云之志」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_43279637/article/details/84842189
In aggregated query without GROUP BY, expression #2 of SELECT list contains nonaggregated column...相关推荐
- In aggregated query without GROUP BY, expression #2 of SELECT list contains nonaggregated column
maven项目报错error: expression #2 of SELECT list contains nonaggregated column 'newhelp.appr.title'; thi ...
- mysql查询出现In aggregated query without GROUP BY, expression #1 of SELECT list contains nonaggregated c
1.问题: Error querying database. Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: In ...
- MYSQL||报错:In aggregated query without GROUP BY, expression #1 of SELECT list contains nonaggregated
碎碎念: 兄弟萌,我胡汉三又回来啦(。・∀・)ノ゙嗨,最近在期末考,一不小心二十几天没发博了,年底KPI没冲成功,今天就来补一下下§(* ̄▽ ̄*)§ 一.问题描述 今天在牛客网做SQL的题:牛客的课程 ...
- mysql:In aggregated query without GROUP BY, expression #1 of SELECT list contains...........
文章目录 问题描述 问题溯源 解决方式一 解决方法二 附录: 问题描述 下面是报错截图: 1140 - In aggregated query without GROUP BY, expression ...
- [42000][1140] In aggregated query without GROUP BY, expression #2 of SELECT list contains nonaggreg
项目报错error: expression #2 of SELECT list contains nonaggregated column 'newhelp.appr.title'; this is ...
- mysql 报错:1140 In aggregated query without GROUP BY, expression #
1140 In aggregated query without GROUP BY, expression #1 of SELECT list contains nonaggregated colum ...
- In aggregated query without GROUP BY报错
记录一下关于mysql的一个报错问题解决方案:In aggregated query without GROUP BY, expression #1 of SELECT list contains n ...
- In aggregated query without GROUP BY
1.问题: 查询语句: select count(support) supportCount,count(collection) collectionCount, support,collection ...
- MySQLSyntaxErrorException: In aggregated query without GROUP BY聚合查询语法异常
MySQLSyntaxErrorException: In aggregated query without GROUP BY,this is incompatible with sql_mode=o ...
最新文章
- Java泛型:泛型类、泛型接口和泛型方法
- ACM——模拟(hard) 刷题总结
- 打造一个宇宙 星系模拟产生对宇宙进化惊人见解
- python、PyTorch图像读取与numpy转换
- [设计模式]模板方法模式
- 012.对netmap API的解读
- MRI骨水肿是早期未分化关节炎演变为RA的独立预测预测因素
- 【Docer】Docer安装MySQL并且远程登录
- tomcat使用线程池配置高并发连接
- 网页内容复制粘贴(三种方案 兼容多种浏览器)
- 知乎热问:一个程序员的水平能差到什么程度?
- 不同方式遍历Map集合
- 【PyTorch】深度学习实践之 CNN基础篇——卷积神经网络跑Minst数据集
- 猿大师播放器网页播放海康威视RTSP流闪退,用新版VLC播放器播放也闪退,但是用某个老版本VLC播放器却没问题,该怎么办?
- Win10自带超级截屏利器
- 基于FPGA的虚拟示波器的设计
- SparkStreaming动态读取配置文件
- 2019 初入IT十年(下)---- 视线所及只剩生活
- 初学Linux很土鳖?带你认识Linux,如何安装Linux?
- apple开发者文档关于KVC和KVO文档的一些渣翻——这里是原地址
热门文章
- 公共界面_公共建筑东营市档案馆能耗计量分析系统
- linux桌面版自动更新关闭了,桌面应用|开启 Ubuntu 系统自动升级
- oracle10g检测未通过,win64bit安装oracle 10g版本检查未通过解决 提示要求的结果: 5.0,5.1,5.2,6.0 之一 实际结果: 6.1...
- mysql 复制方式_MySQL复制方法
- 腾讯视频下载安装_如何上传视频到腾讯视频平台
- Windows平台RTMP推送|轻量级RTSP服务实现本地摄像头|屏幕|叠加数据预览
- DHCP租用信息导出方案
- 如何将Springboot项目成功部署到linux服务器上?
- 再也不怕SVN冲突:轻松解决SVN冲突
- php文件防删改,PHP实现增删改查以及防SQL注入