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...相关推荐

  1. 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 ...

  2. 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 ...

  3. MYSQL||报错:In aggregated query without GROUP BY, expression #1 of SELECT list contains nonaggregated

    碎碎念: 兄弟萌,我胡汉三又回来啦(。・∀・)ノ゙嗨,最近在期末考,一不小心二十几天没发博了,年底KPI没冲成功,今天就来补一下下§(* ̄▽ ̄*)§ 一.问题描述 今天在牛客网做SQL的题:牛客的课程 ...

  4. mysql:In aggregated query without GROUP BY, expression #1 of SELECT list contains...........

    文章目录 问题描述 问题溯源 解决方式一 解决方法二 附录: 问题描述 下面是报错截图: 1140 - In aggregated query without GROUP BY, expression ...

  5. [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 ...

  6. mysql 报错:1140 In aggregated query without GROUP BY, expression #

    1140 In aggregated query without GROUP BY, expression #1 of SELECT list contains nonaggregated colum ...

  7. In aggregated query without GROUP BY报错

    记录一下关于mysql的一个报错问题解决方案:In aggregated query without GROUP BY, expression #1 of SELECT list contains n ...

  8. In aggregated query without GROUP BY

    1.问题: 查询语句: select count(support) supportCount,count(collection) collectionCount, support,collection ...

  9. MySQLSyntaxErrorException: In aggregated query without GROUP BY聚合查询语法异常

    MySQLSyntaxErrorException: In aggregated query without GROUP BY,this is incompatible with sql_mode=o ...

最新文章

  1. Java泛型:泛型类、泛型接口和泛型方法
  2. ACM——模拟(hard) 刷题总结
  3. 打造一个宇宙 星系模拟产生对宇宙进化惊人见解
  4. python、PyTorch图像读取与numpy转换
  5. [设计模式]模板方法模式
  6. 012.对netmap API的解读
  7. MRI骨水肿是早期未分化关节炎演变为RA的独立预测预测因素
  8. 【Docer】Docer安装MySQL并且远程登录
  9. tomcat使用线程池配置高并发连接
  10. 网页内容复制粘贴(三种方案 兼容多种浏览器)
  11. 知乎热问:一个程序员的水平能差到什么程度?
  12. 不同方式遍历Map集合
  13. 【PyTorch】深度学习实践之 CNN基础篇——卷积神经网络跑Minst数据集
  14. 猿大师播放器网页播放海康威视RTSP流闪退,用新版VLC播放器播放也闪退,但是用某个老版本VLC播放器却没问题,该怎么办?
  15. Win10自带超级截屏利器
  16. 基于FPGA的虚拟示波器的设计
  17. SparkStreaming动态读取配置文件
  18. 2019 初入IT十年(下)---- 视线所及只剩生活
  19. 初学Linux很土鳖?带你认识Linux,如何安装Linux?
  20. apple开发者文档关于KVC和KVO文档的一些渣翻——这里是原地址

热门文章

  1. 公共界面_公共建筑东营市档案馆能耗计量分析系统
  2. linux桌面版自动更新关闭了,桌面应用|开启 Ubuntu 系统自动升级
  3. oracle10g检测未通过,win64bit安装oracle 10g版本检查未通过解决 提示要求的结果: 5.0,5.1,5.2,6.0 之一 实际结果: 6.1...
  4. mysql 复制方式_MySQL复制方法
  5. 腾讯视频下载安装_如何上传视频到腾讯视频平台
  6. Windows平台RTMP推送|轻量级RTSP服务实现本地摄像头|屏幕|叠加数据预览
  7. DHCP租用信息导出方案
  8. 如何将Springboot项目成功部署到linux服务器上?
  9. 再也不怕SVN冲突:轻松解决SVN冲突
  10. php文件防删改,PHP实现增删改查以及防SQL注入