SQL逻辑运算符优先级: And and Or

标签 sql logical-operators operator-precedence

下面的两个陈述是否等效?

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

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

最佳答案

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

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

关于SQL逻辑运算符优先级: And and Or,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1241142/

相关文章:

indexing - Fortran - 逻辑索引

scala - 为什么 !== 在 Scala 中的优先级低于 ===?

mysql - 使用许多连接优化 SQL 查询

mysql - 在给定日期之后选择具有 HAVING 的行

mysql - 需要有关 mysql 日期范围查询的帮助

matlab - | 之间有什么区别?和||在 MATLAB 中?

MySQl 创建函数来检查字符串是否正确

c++ - 如何在 else-if 语句中正确使用 or 语句 (||)

c - C 中运算符的优先级和结合性

c - 为什么这些构造使用增量前和增量后未定义的行为?