mysql Syntax error or access violation: 1055 Expression #1 of SELECT list is not in GROUP BY clause

今天使用mysql group by函数的时候出现了这样一个提示:mysql版本是5.7

Syntax error or access violation: 1055 Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'XXX.Y.ZZZZ' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

出现这个问题主要是和mysql中SQL模式中的only_full_group_by有关。在mysql5.7之前的版本,MySQL没有检测到功能依赖项,only_full_group_by在默认情况下是不启用的。在mysql5.7中only_full_group_by 默认是启用的。所以MySQL会拒绝选择列表、条件或顺序列表引用的查询,这些查询将引用组中未命名的非聚合列,而不是在功能上依赖于它们。

1.查看当前mysql的sql模式

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

mysql> SHOW SESSION VARIABLES;

mysql> SHOW GLOBAL VARIABLES;

mysql> select @@sql_mode;

可以看到session和global中的sql_mode 的值全是:

出现这个意味着你的sql模式启用了only_full_group_by。将它去掉就不会有报错了。

那么怎么样才能让他去掉?有两种方式。

1.执行sql语句修改sql_mode的值

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

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

第一种就是有一个缺点:设置完成以后,好像只对现在使用使用数据库有用,一旦重启mysql服务,还是会依然报这个错误。所以我推荐使用第二种方式。

2.设置mysql的配置文件

 

增加这一行语句:

重新启动mysql服务看看是不是就可以使用group by这个函数了?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值