为了账号安全,请及时绑定邮箱和手机立即绑定

SQL逻辑操作符优先性:和或

SQL逻辑操作符优先性:和或

慕斯王 2019-06-17 14:34:40
SQL逻辑操作符优先性:和或以下两项声明是否相等?SELECT [...]FROM [...]WHERE some_col in (1,2,3,4,5) AND some_other_expr和SELECT [...]FROM [...]WHERE some_col in (1,2,3) or some_col in (4,5) AND some_other_expr我能用什么真值表来证实这一点吗?
查看完整描述

3 回答

?
守着星空守着你

TA贡献1799条经验 获得超8个赞

And优先于Or所以即使a <=> a1 Or a2

Where a And b

Where a1 Or a2 And b,

因为这将被执行为

Where a1 Or (a2 And b)

为了使它们保持不变,您想要的是以下内容(使用括号覆盖优先级规则):

 Where (a1 Or a2) And b

这里有一个例子来说明:

Declare @x tinyInt = 1Declare @y tinyInt = 0Declare @z tinyInt = 0Select Case When @x=1 OR @y=1 And @z=1 Then 'T' Else 'F' End -- outputs 
TSelect Case When (@x=1 OR @y=1) And @z=1 Then 'T' Else 'F' End -- outputs F

对于那些喜欢查阅参考资料的人(按字母顺序排列):


查看完整回答
反对 回复 2019-06-17
?
繁花如伊

TA贡献2012条经验 获得超12个赞

我再补充两点:

  • “IN”实际上是带有括号的串行OR。
  • 在我所知道的每一种语言中都优先于OR

所以,这两个表达式就是不相等的。

WHERE some_col in (1,2,3,4,5) AND some_other_expr--to the optimiser is thisWHERE
     (
     some_col = 1 OR
     some_col = 2 OR 
     some_col = 3 OR 
     some_col = 4 OR 
     some_col = 5
     )
     AND
     some_other_expr

因此,当您中断IN子句时,可以将串行OR拆分起来,并更改优先级。


查看完整回答
反对 回复 2019-06-17
?
拉风的咖菲猫

TA贡献1995条经验 获得超2个赞

  1. 算术算子
  2. 级联算子
  3. 比较条件
  4. 是[不]空,就像,[不]在
  5. [不]之间
  6. 不等于
  7. 非逻辑条件
  8. 逻辑条件
  9. 或逻辑条件

可以使用括号覆盖优先级规则。


查看完整回答
反对 回复 2019-06-17
  • 3 回答
  • 0 关注
  • 560 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信