最近接了个项目,因为项目要与第三方协作的原因需要用到mysql5.7.x版本。然后就碰到了这个新老版本的差异导致的group by问题。

mysql5.7.x版本默认是开启了 only_full_group_by 模式的,但开启这个模式后,原先的 group by 语句就报错,然后又把它移除了。
一旦开启 only_full_group_by,感觉group by将变成和distinct一样,只能获取受到其影响的字段信息,无法和其他未受其影响的字段共存,这样group by的功能将变得十分鸡肋了!

具体出错提示:

[Err] 1055 - Expression #1 of ORDER BY clause is not in GROUP BY clause and contains nonaggregated column ‘information_schema.PROFILING.SEQ’ which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

解决方式如下:

1、在sql查询语句中不需要group by的字段上使用any_value()函数
什么?改代码? 改代码是不可能的这辈子都不可能!!!这种对于已经开发完成的项目不太合适,毕竟要把原来的sql都给修改一遍!

2、修改my.cnf(windows下是my.ini)配置文件,删掉only_full_group_by这一项
若我们项目的mysql安装在Debian上面,找到这个文件打开一看,里面并没有sql_mode这一配置项,想删都没得删。
那该怎么办呢
当然,还有别的办法,打开mysql命令行,执行命令:

select @@global.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

我们将ONLY_FULL_GROUP_BY去掉重新设置值即可:

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';

上面是改变了全局sql_mode,只对新建的数据库有效。对于已存在的数据库,则需要在对应的数据下执行:

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';

这样就大功告成了!