1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > mysql 5.6 5.7不兼容_同一条sql在MySQL数据库5.6和5.7版本遇到的问题

mysql 5.6 5.7不兼容_同一条sql在MySQL数据库5.6和5.7版本遇到的问题

时间:2018-12-31 22:15:39

相关推荐

mysql 5.6 5.7不兼容_同一条sql在MySQL数据库5.6和5.7版本遇到的问题

本文主要向大家介绍了同一条sql在MySQL数据库5.6和5.7版本遇到的问题 ,通过具体的内容向大家展现,希望对大家学习MySQL数据库有所帮助。

之前用的是mysql5.6版本,执行select*fromtablegroupbycolunm是可以出结果的,

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

Expression#1ofORDERBYclauseisnotinGROUPBYclauseandcontainsnonaggregatedcolumn‘information_schema.xxxxx.SEQ‘whichisnotfunctionallydependentoncolumnsinGROUPBYclause;thisisincompatiblewithsql_mode=only_full_group_by

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

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

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

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

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

本文由职坐标整理并发布,希望对同学们学习MySQL有所帮助,更多内容请关注职坐标数据库MySQL数据库频道!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。