小编典典

SQL 逻辑运算符优先级:与和或

all

下面的两种说法是等价的吗?

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

是否有某种真值表可以用来验证这一点?


阅读 117

收藏
2022-06-22

共1个答案

小编典典

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 = 1
Declare @y tinyInt = 0
Declare @z tinyInt = 0

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

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

2022-06-22