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 Syntax error or access violation: 1055 Expression #1 of SELECT list is not in GROUP BY clause_第1张图片

增加这一行语句:

mysql Syntax error or access violation: 1055 Expression #1 of SELECT list is not in GROUP BY clause_第2张图片

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

你可能感兴趣的:(mysql)