当前位置:Gxlcms > 数据库问题 > 同一条sql在mysql5.6和5.7版本遇到的问题。

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

时间:2021-07-01 10:21:17 帮助过:69人阅读

其实相对于语法来说,非聚集字段不能出现在查询列表中,这条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版本遇到的问题。

标签:color   mysql 5.6   div   sub   lun   from   aggregate   ble   建议   

人气教程排行