发布网友 发布时间:2022-04-26 03:59
共5个回答
懂视网 时间:2022-05-01 22:59
其实相对于语法来说,非聚集字段不能出现在查询列表中,这条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 建议
热心网友 时间:2022-05-01 20:07
条件只是new_rank < 4热心网友 时间:2022-05-01 21:25
@temp和@rank 在最里层 红色那部分 需要重新赋值一下,在select后边 加上 (select @temp:=0),(select @rank:=0)热心网友 时间:2022-05-01 23:00
有办法只执行一次么热心网友 时间:2022-05-02 00:51
那说明你的程序在执行的过程中有SQL语句有改动 ,要么你的程序链接数据库不一致,启动BUG模式跟踪一下就知道了追问并没有改,SQL语句写好后,就点了两次执行按钮,其他都没动。