报错信息如下:
Caused by: java.sql.SQLSyntaxErrorException:
Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated
column 'clothing_db.a.num' 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参考手册。)
那么怎么办呢?
网上给出的例子让修改 ==mysql.cnf ==文件,或者 my.cnf 文件,但是我通过命令查找,在 usr/share/mysql 下面根本就没有这些文件,但是我在 etc 下发现了此文件
进入阅读改文件模式,这里我已经在最后一行加上这一段代码了
[mysqld]
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
进入编辑模式
vi my.cnf
进入正式修改模式,点击键盘上的 i ,会出现以下界面(insert)
将代码复制到最后一行
修改好之后,点击键盘上的 Esc 键 退出编辑模式,你会发现界面上没有 insert 了,但是还没有真正的保存文件,再次点击键盘上的 【shift + :】
输入命令 wq 并回车,意思是退出并保存
上面这种方式可以永久的修改 mysql 的配置,并不会在 mysql 重启的时候重新刷新
此链接下的修改方式只是暂时性修改,重启 mysql 后失效
https://blog.csdn.net/sofeware333/article/details/108286880 附加图片说明
推荐学习链接
https://blog.csdn.net/weixin_34207964/article/details/113397088