修改mysql sql_mode不生效_mysql 5.7.X版本 解决sql_mode设置不生效。

现在谁在报专业报计算机相关的就相当于49年报国军

记来自几位不是圈内的大姐的对话

部署项目使用到了mysql 5.7.x版本,结果一如既往,bug迎面而来。

Caused by: java.sql.SQLSyntaxErrorException: Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'T1.ID' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

意思大概是SELECT列表的表达式不在GROUP BY子句中,并且包含未聚合的列'T1.ID',该列在功能上不依赖于GROUP BY子句中的列(google翻译😂😂😂)

言归正传:ONLY_FULL_GROUP_BY是MySQL提供的一个sql_mode,通过这个sql_mode来提供SQL语句GROUP BY合法性的检查,在MySQL的sql_mode是非ONLY_FULL_GROUP_BY语义时。一条select语句,MySQL允许target list中输出的表达式是除聚集函数或group by column以外的表达式,这个表达式的值可能在经过group by操作后变成undefined。也就是说只能返回count(*)等参数了。如何解决:此处有两种方法:一种就是直接修改数据的sql_mode:(此方法本人未做校验);

解决方法:

使用

SET @@global.sql_mode ="STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION";

(exit后在进来select一遍@@global.sql_mode,跟没改一个样!原来这个设置的是个会话级别的。)

真正解决我的问题的是这种方法:

关闭mysql服务

vi  my.cnf(或者my.ini)

在[mysqld]节点下添加一句 sql_mode=NO_UNSIGNED_SUBTRACTION,NO_ENGINE_SUBSTITUTION

跟下面一样

c4e65813947e

下面

于是我就

sudo vi  /usr/local/mysql-5.7.27-macos10.14-x86_64/support-files/my-default.cnf(路径)

找到[mysqld]下增加

sql_mode=NO_UNSIGNED_SUBTRACTION,NO_ENGINE_SUBSTITUTION

esc  :wq!(退出保存vi)

重启mysql服务

over

最后去验证一下sql_mode改没改

mysql -u root -p

select @@global.sql_mode;

看到下图

c4e65813947e

下图

c4e65813947e

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值