• 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必知必会》

  • 相关阅读:
    「总结」容斥。二.反演原理 3.约数容斥
    「总结」容斥。二.反演原理 2.组合容斥
    「总结」容斥。二.反演原理 1.子集容斥
    「总结」容斥。一.容斥原理
    「考试」num (破800纪念)
    「刷题」 网络
    「考试」 Or
    「考试」weight
    「刷题」GERALD07加强版
    「刷题」Triple
  • 原文地址:https://www.cnblogs.com/Guhongying/p/10542120.html
Copyright © 2020-2023  润新知