在MySQL中,NOT和!做同样的事情(逻辑上没有),但它们在不同的操作符前面。!出现在算术运算符和相等运算符之上,NOT低于这些运算符,但高于逻辑运算符,如AND和OR。请参阅http://dev.mysql.com/doc/refman/5.7/en/operator-precedence.html
在MySQL 3和4中,它们具有相同的优先级。为什么要做这个改变?
发布于 2014-01-16 21:23:13
考虑到引入了一个标志HIGH_NOT_PRECEDENCE来恢复旧的行为,我认为文档的这一部分解释得最好:
NOT操作符的优先级是这样的,例如在b和c之间的表达式,如NOT (b和c之间的a)。在一些较早版本的MySQL中,表达式被解析为(而不是a) b和c之间的表达式。
换句话说,NOT的行为没有很多人认为的那样,因此优先级发生了变化。在编写!a时,您不太可能被这个问题绊倒,因为它更直观地表示您在否定a。
https://stackoverflow.com/questions/21172998
复制相似问题