项目场景:
将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_mode
为only_full_group_by
的情况下,MySQL 数据库会禁止此类型的查询。在 MySQL 5.7.5 版本之后,默认SQL模式中包含了
ONLY_FULL_GROUP_BY
选项,要求在GROUP BY子句中的所有列都必须出现在SELECT语句中,并且不能含有聚合函数的列
解决方案:
tip:推荐使用第三种方案(解决流程采用第三种解决方案)
将 SELECT 子句中的所有字段都添加到 GROUP BY 子句中。如下:
SELECT nikename, COUNT(*) FROM comment_user GROUP BY nikename;
对于非聚合函数的字段,可以使用 MySQL 中的聚合函数对其进行聚合,即将其放入 SELECT 子句中,并附加相应的聚合函数操作。如下:
SELECT MAX(nikename), COUNT(*) FROM comment_user GROUP BY user_id;
可以修改
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>