Mysql 升级到5.7之后sql_mode默认开启only_full_group_by,这时进行一些group by查询的时候就会报以下错误:
原因是Mysql5.7模式中,默认启用了only_full_group_by。
ONLY_FULL_GROUP_BY是MySQL提供的一个sql_mode,通过这个sql_mode来提供SQL语句GROUP BY合法性的检查。
官网给的解答,英语比较好的同学可以直接看官网:
https://dev.mysql.com/doc/refman/5.7/en/sql-mode.html#sqlmode_only_full_group_by
英语不好的同学接着往下看:
this is incompatible with sql_mode=only_full_group_by这句话提示了这违背了mysql的规则,only_full_group_by,也就是说在执行的时候先分组,根据查询的字段(select的字段)在分组的内容中取出,所以查询的字段全部都应该在group by分组条件内;一种情况例外,查询字段中如果含有聚合函数的字段不用包含在group by中,就像我上面的count(openid)。后来发现Order by排序条件的字段也必须要在group by内,排序的字段也是从分组的字段中取出。 不明白的可以去看一下。
解决方法:
1. 首先查看sql_mode: SELECT @@sql_mode;
用命令更新mysql的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’;
2.注意第1种修改,重启mysql后就会失效,如果想长久生效,就需要在mysql的配置文件 my.cnf 里[mysqld]下边添加并重启sql_mode =STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION;
3.利用ANY_VALUE()这个函数 https://dev.mysql.com/doc/refman/5.7/en/miscellaneous-functions.html#function_any-value
This function is useful for GROUP BY queries when the ONLY_FULL_GROUP_BY SQL mode is enabled, for cases when MySQL rejects a query that you know is valid for reasons that MySQL cannot determine. The function return value and type are the same as the return value and type of its argument, but the function result is not checked for the ONLY_FULL_GROUP_BY SQL mode.
把sql语句修改成 :
与时俱进,我推荐大家用第三种方法.