MYSQL5.7版本sql_mode=only_full_group_by问题
最近接了个项目,因为项目要与第三方协作的原因需要用到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'; |
这样就大功告成了!