首页 > 代码库 > 同一条sql在mysql5.6和5.7版本遇到的问题。
同一条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版本遇到的问题。
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。