首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么那不是和!在MySQL 5中有不同的操作符优先级吗?

为什么那不是和!在MySQL 5中有不同的操作符优先级吗?
EN

Stack Overflow用户
提问于 2014-01-16 21:13:54
回答 1查看 42关注 0票数 1

在MySQL中,NOT!做同样的事情(逻辑上没有),但它们在不同的操作符前面。!出现在算术运算符和相等运算符之上,NOT低于这些运算符,但高于逻辑运算符,如ANDOR。请参阅http://dev.mysql.com/doc/refman/5.7/en/operator-precedence.html

在MySQL 3和4中,它们具有相同的优先级。为什么要做这个改变?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-01-16 21:23:13

考虑到引入了一个标志HIGH_NOT_PRECEDENCE来恢复旧的行为,我认为文档的这一部分解释得最好:

NOT操作符的优先级是这样的,例如在b和c之间的表达式,如NOT (b和c之间的a)。在一些较早版本的MySQL中,表达式被解析为(而不是a) b和c之间的表达式。

换句话说,NOT的行为没有很多人认为的那样,因此优先级发生了变化。在编写!a时,您不太可能被这个问题绊倒,因为它更直观地表示您在否定a

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21172998

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档