SQL关于WHERE 的计算次序

WHERE可包含任意数目的AND和OR操作符。允许两者结合以进行复杂 和高级的过滤。 但是OR和AND操作符是有先后次序的。

比如,原意是想找出 3班和5班年龄为21岁的同学,使用 :SELECT * FROM STU WHERE CNO=3 OR CNO=5 AND SAGE=21;

但是,结果却是这样的:

明显有个20岁的不符合!

原因在于计 算的次序。SQL(像多数语言一样)在处理OR操作符前,优先处理AND操 作符。当SQL看到上述WHERE子句时,它理解为班级为5班且年龄为21岁的同学,或者班级为3班的所有同学!而不管其年龄如何!换句话说,由于AND在计算次序中优先级更高,操作符被错误地组合了。

此问题的解决方法是使用圆括号明确地分组相应的操作符。如下:

SELECT * FROM STU WHERE (CNO=3 OR CNO=5) AND SAGE=21;

结果就是想要的!

 在WHERE子句中使用圆括号  任何时候使用具有AND和OR操作 符的WHERE子句,都应该使用圆括号明确地分组操作符。不要 过分依赖默认计算次序,即使它确实是你想要的东西也是如 此。使用圆括号没有什么坏处,它能消除歧义。《MySQL必知必会》

原文地址:https://www.cnblogs.com/Guhongying/p/10542120.html