项目报错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:进入mysql.exe,

(如果直接点击exe会闪退,打开cmd进入mysql所在盘,进入mysql文件夹,即输入cd mysql,再进入bin文件夹,即输入cd bin,最后输入mysql -uroot -proot ,-u后是账号 -p后是密码)

命令行中输入:

查看sql_model参数命令:

SELECT @@GLOBAL.sql_mode;SELECT @@SESSION.sql_mode;

可以看到框内第一个显示的就有 ONLY_FULL_GROUP_BY

去除的指令:

set @@global.sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';set sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';

再次输入查看指令,可以发现 ONLY_FULL_GROUP_BY 已经去除
不过这种情况治标不治本,一旦mysql重启之后又会恢复。

2:修改MySQL的配置文件,

windows下找到MySQL的安装目录的my.ini文件,修改其中的配置为不启动ONLY_FULL_GROUP_BY模式,

删掉带有ONLY_FULL_GROUP_BY的模式就ok了。

如果本身就没有写这个配置,将以下复制到文件中的[mysqld]下:
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是8.0及以上的版本,使用如下配置:sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
与前面的相比, 删去了 NO_AUTO_CREATE_USER, 因为8.0以上已经取消了这个关键字

如果没有找到my.ini文件,
去系统的隐藏文件夹查看,在某个盘下输入%ProgramData%然后搜索MySQL的my.ini文件
————————————————

参考链接:https://blog.csdn.net/qq_43279637/article/details/84842189

[42000][1140] In aggregated query without GROUP BY, expression #2 of SELECT list contains nonaggreg相关推荐

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

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

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

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

  3. 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 nona ...

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

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

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

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

  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. JS学习梳理(三)类型和语法
  2. 深度学习中的3个秘密:集成、知识蒸馏和蒸馏
  3. LINQ via C# 系列文章
  4. 438. Find All Anagrams in a String
  5. 网易云信获中国IM云服务领域首个CSA STAR认证
  6. 巨蟒python全栈开发flask11项目开始3
  7. .NET Core 2.0使用NLog
  8. Java——反射(Class.forName()读取配置文件举例).
  9. 怎样保存python源程序_五分钟教会你如何编写、保存与运行 Python 程序
  10. 修改项目生成Gemfile的模板
  11. 适合小白的word基本操作
  12. 微信小程序-模拟器某些页面空白-引用 VantUI 后,页面空白
  13. 二十四节气—处暑,暑气渐轻,热力不减。
  14. 小时候玩一天的打砖块小游戏(附完整源码)
  15. COSTDOWN Project's BSP(一)
  16. java8的Effectively final
  17. 警惕一些野鸡国际出版社
  18. 计算机网络组成复习笔记
  19. 个人永久性免费-Excel催化剂功能第24波-批量发送邮件并指点不同附件不同变量...
  20. 排查Java宕机,weblogic宕机问题排查

热门文章

  1. 音乐社会计算机英语,计算机_英语口语_单曲在线试听_酷我音乐
  2. php生成aes密钥,为AES加密生成密钥的安全性
  3. 光缆在线监测系统研究
  4. java动态代理简介
  5. (转)浏览器广告拦截规则,ublock origin自用规则!
  6. Centos7.3 卸载 Nginx(彻底卸载) 并重新安装 Nginx(RPM源yum安装)
  7. cocos2d for iphone development
  8. (LKD3读书记录)Chap5:系统调用
  9. 微信公众平台天气查询,火车票查询,快递查询,小黄鸡,翻译,公交查询的实现
  10. Android Studio 3.0中mipmap-anydpi-v26是什么东东