1. ホーム
  2. sql

[解決済み】SQLロジックの演算子の優先順位。AndとOr

2022-04-12 23:52:06

質問

次の2つの文は等価か?

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

参考文献を調べたい方へ(アルファベット順)。