同一条sql在mysql5.6和5.7版本遇到的问题。

Posted 九人稚。

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了同一条sql在mysql5.6和5.7版本遇到的问题。相关的知识,希望对你有一定的参考价值。

之前用的是mysql 5.6版本,执行select * from table group by colunm 是可以出结果的,

但是切换的5.7版本,这条sql就报错,

Expression #1 of ORDER BY clause is not in GROUP BY clause and contains nonaggregated column ‘information_schema.xxxxx.SEQ‘ which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

其实相对于语法来说,非聚集字段不能出现在查询列表中,这条sql本身就是错误的,那么为什么5.6mysql可以执行呢?

找了好久发现是原来是sql mode的数据库数据类型的问题。

5.7开始,mysql就开始严格遵从SQL 92规范,凡事没有遵循规范的sql都不予执行,当然可以通过配置修改成5.6版本的值,但是本人不建议这么做。

 

可以通过sql查询出当前sql mode值

 

select @@GLOBAL.sql_mode;-- 查询全局值
select @@SESSION.sql_mode; -- 查询当前会话值
5.7版本的值为: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
5.6版本的值为:STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION

 

以上是关于同一条sql在mysql5.6和5.7版本遇到的问题。的主要内容,如果未能解决你的问题,请参考以下文章

MySQL5.6到5.7版本升级采用IN-PLACE的升级方式需要具体关注的地方

mysql 5.7 在中等 sql 中比 mysql 5.6 慢很多

mysql5.6好还是mysql5.7好

mysql5.5和5.7的区别

mysql5.6升级5.7

mysql5.6以上(适用5.7)免安装版本 终极配置