您的位置:首页 > 数据库 > MySQL

mysql8.0.17异常Expression #2 of SELECT list is not in GROUP BY clause and contains nonaggregated colum

2020-02-02 06:51 609 查看

记一次mysql8.0.17异常的解决方式:

windows环境下新安装的mysql没版本号为:8.0.17,之前时5.多的版本。升级完后,启动项目报错:

Expression #2 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'x.xxx' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

 

 

原因是: 

MySQL 5.7.5及以上实现了对功能依赖的检测。如果启用了only_full_group_by SQL模式(在默认情况下是这样),那么MySQL就会拒绝选择列表、条件或顺序列表引用的查询,这些查询将引用组中未命名的非聚合列,而不是在功能上依赖于它们。(在5.7.5之前,MySQL没有检测到功能依赖项,only_full_group_by在默认情况下是不启用的。关于前5.7.5行为的描述,请参阅MySQL 5.6参考手册。)

 

执行以下个命令,可以查看 sql_mode 的内容。

 

mysql> SHOW SESSION VARIABLES;

 

mysql> SHOW GLOBAL VARIABLES;

 

 

可见session和global 的sql_mode的值都为:

ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION

(如果只有其中一个有此内容的话,下面只需要修改有的那个,亲测可行)

 

解决方式:执行以下sql

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

 

set session sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';

 

 

最后这一步至关重要,好多教程中都没有写,上面是能解决问题,但是当你的mysql重启后,问题就又恢复了。

打开你的my.ini文件在[mysqld] 下面加上:sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION

记住 位置一定不能错!!!要不然不生效

  • 点赞
  • 收藏
  • 分享
  • 文章举报
她说- 发布了8 篇原创文章 · 获赞 0 · 访问量 1607 私信 关注
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐