本文主要向大家介绍了同一条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数据库频道!