本文介绍: 这个异常表示在 MySQL 查询语句执行时,SELECT 列表中的一些字段未在 GROUP BY 子句出现可能会导致输出结果不一致或者不正确。在设置 sql_modeonly_full_group_by 的情况下,MySQL 数据库会禁止此类型查询。已解决!!! 在 MySQL 5.7.5 版本之后,默认SQL模式包含了ONLY_FULL_GROUP_BY选项,要求在GROUP BY子句中的所有列都必须出现在SELECT语句中,并且不能含有聚合函数的列

项目场景

jar部署至linix运行运行提示 :  com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException 异常报错


问题描述

 MySQLSyntaxErrorException 异常报错内容如下

com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: 
Expression #11 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'springcloud.comment_user.nikename' 
which is not functionally dependent on columns in GROUP BY clause; 
this is incompatibcle with sql_mode=only_full_group_by

原因分析

这个异常表示在 MySQL 查询语句执行时,SELECT 列表中的一些字段未在 GROUP BY 子句出现可能会导致输出结果不一致或者不正确

设置 sql_modeonly_full_group_by 的情况下,MySQL 数据库会禁止此类型的查询

在 MySQL 5.7.5 版本之后,默认SQL模式包含ONLY_FULL_GROUP_BY选项,要求在GROUP BY子句中的所有列都必须出现在SELECT语句中,并且不能含有聚合函数的列


解决方案

tip推荐使用第三方案(解决流程采用三种解决方案)

  1. 将 SELECT 子句中的所有字段添加到 GROUP BY 子句中。如下

    SELECT nikename, COUNT(*) FROM comment_user GROUP BY nikename;
  2. 对于非聚合函数的字段,可以使用 MySQL 中的聚合函数对其进行聚合,即将其放入 SELECT 子句中,并附加相应的聚合函数操作如下

    SELECT MAX(nikename), COUNT(*) FROM comment_user GROUP BY user_id;
  3. 可以修改 sql_mode,将 only_full_group_by 模式关闭如下

    SET GLOBAL sql_mode=(SELECT REPLACE(@@sql_mode,'ONLY_FULL_GROUP_BY',''));

请注意,开启 only_full_group_by 模式是为了减少 SQL 查询的歧义性和错误率,如果您不确定修改 SQL_MODE 的影响,请谨慎和慎重考虑。同时,建议编写 SQL 查询语句时注

意 GROUP BY 子句书写规则,避免出现此类异常

解决流程

一、临时解决

 1. 进入mysql 修改(此修改为临时性,重启mysql失效

mysql -uroot -p

 2. 设置sql_mode @GLOBAL.sql_mode 和 @SESSION.sql_mode

 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';

 3. 退出 quit; 服务器异常报错解决。当一旦 service mysqld restart; 重启mysql,此设置失效异常报错依旧存在

二、永久解决

修改Linux系统中MySQL配置文件/etc/my.cnf,可按如下步骤进行:

 1. 进入MySQL配置文件所在的目录,如/etc/目录可以使用以下命令进入目录

cd /etc/

 2. 打开my.cnf文件可以使用vim编辑器打开

vim my.cnf

 3. 编辑my.cnf文件,在最后一行添加以下内容

tip:别忘记添加[mysqld]哦,否则是不生效的。

[mysqld]
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION

 4.  保存关闭my.cnf文件。在 Vim 编辑器中,可以按 Esc然后输入 :wq 来保存并退出

 5. 重新启动MySQL服务,以使更改生效可以使用以下命令重启MySQL服务

sudo systemctl restart mysqld.service

 6.查看结果进入Mysql执行如下指令

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

 运行结果如下时,MySQL配置文件中的sql_mode参数值已被修改,MySQL将不再对GROUP BY   查询产生 “Expression #11 of SELECT list is not in GROUP BY clause异常

mysql> SELECT @@SESSION.sql_mode;
+----------------------------------------------------------------------------------------------------+
| @@SESSION.sql_mode                                                                                 |
+----------------------------------------------------------------------------------------------------+
| STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION |
+----------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

mysql> 
mysql> select @@GLOBAL.sql_mode;
+----------------------------------------------------------------------------------------------------+
| @@GLOBAL.sql_mode                                                                                  |
+----------------------------------------------------------------------------------------------------+
| STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION |
+----------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

mysql> 

原文地址:https://blog.csdn.net/AA2534193348/article/details/130910849

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_36554.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注