mysql5.7报错thisisincompatiblewithsql_mode=only_full_group_by怎么解决
本篇内容主要讲解“MySQL5.7报错this is incompatible with sql_mode=only_full_group_by怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mysql5.7报错this is incompatible with sql_mode=only_full_group_by怎么解决”吧!
成都创新互联自2013年起,先为鹤山等服务建站,鹤山等地企业,进行企业商务咨询服务。为鹤山企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。
下载安装的是最新版的mysql5.7.x版本,默认是开启了 only_full_group_by
模式的,但开启这个模式后,原先的 group by
语句就报错,然后又把它移除了。
一旦开启 only_full_group_by
,感觉,group by
将变成和 distinct
一样,只能获取受到其影响的字段信息,无法和其他未受其影响的字段共存,这样,group by
的功能将变得十分狭窄了
only_full_group_by
模式开启比较好。
因为在 mysql
中有一个函数: any_value(field)
允许,非分组字段的出现(和关闭 only_full_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_mode
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
2、去掉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';
3、上面是改变了全局sql_mode,对于新建的数据库有效。
到此,相信大家对“mysql5.7报错this is incompatible with sql_mode=only_full_group_by怎么解决”有了更深的了解,不妨来实际操作一番吧!这里是创新互联网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
网站标题:mysql5.7报错thisisincompatiblewithsql_mode=only_full_group_by怎么解决
本文来源:http://ybzwz.com/article/ghphgi.html