0%

Mysql 5.7 sql_mode=only_full_group_by

Mysql 5.7 以上group by向下兼容时容易出现如下错误

1055 - Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column ‘csc_risk.a.DefaultDate’ which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by, Time: 0.035000s 

原因是:MySQL5.7版本默认设置了 sql_mode = only_full_group_by 属性,导致报错。

only_full_group_by 说明

mysql5.7.x版本,默认是开启了 only_full_group_by 模式的,一旦开启 only_full_group_by ,group by 将变成和 distinct 一样,只能获取受到其影响的字段信息,无法和其他未受其影响的字段共存,这样 group by 的功能将变得十分狭窄了。

但是 only_full_group_by 模式还是开启比较好。因为在 mysql 中有一个函数: any_value(field) 允许,非分组字段的出现(和关闭 only_full_group_by 模式有相同效果)。并且也能规范我们写的sql语句

关闭 only_full_group_by

  1. 查看 sql_mode
1
2
3
SELECT @@sql_mode;
# 结果
ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
  1. 去掉ONLY_FULL_GROUP_BY,重新设置值。【新建数据库有效】
1
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';
  1. 上面是改变了全局sql_mode,对于已存在的数据库,则需要在对应的数据下执行
1
SET sql_mode ='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';