助け合いフォーラム
SELECT department_id, employee_id, employee_name, salary, commission, hiredate
FROM employees
WHERE (department_id = 3
OR salary > 400000)
AND commission <= 1200000
OR hiredate > '2008-04-01';
正解
B
C
E
解説
AND演算子とOR演算子ではAND演算子のほうが先に評価されますが、()括弧がある場合は、括弧内の演算子を優先して評価します。
WHERE (department_id = 3
OR salary > 400000)
AND commission <= 1200000
OR hiredate > '2008-04-01';
設問では「(department_id = 3 OR salary > 400000)」の部分が先に評価され、次にANDですので、「DEPARTMENT_ID列が3かSALARY列が400000より大きく、かつCOMMISSION列が1200000以下である」列(E)、または、「HIREDATE列が2008年4月1日より大きい(新しい)」列(B,C)が検索されます。
以上より、
・E
・B
・C
が正解となります。
参考
論理演算子には以下のものがあります。
複数の条件が指定されている場合は、以下の優先順位に従って評価されます。
優先順位を変更したい場合は、先に評価したい演算を()括弧で囲むことで優先順位を高く変更できます。
()括弧がある場合の演算子の優先順位について
お世話になります。
Oracle Master Silver SQLの問題で、()括弧がある場合の演算子の優先順位の問題ですが、
こちらの問題で(department_id = 3 OR salary > 400000)がまず優先されると思うのですが、
そうなると回答:Dも当てはまると思うのですが、不正解です。
何故、回答:Dは不正解なのでしょうか。
宜しくお願い致します。
文が長くなるため問題の
department_id = 3をa
salary > 400000をb
commission <= 120000をc
hiredate > '2008-04-01'をd
とします。
簡単に言うと算数の+と×に変えればわかりやすいです。ORは+、ANDは×です。
問題で表すと(a+b)×c+dになります。
以下は細かい説明です。
問題の括弧を外した場合
a OR b AND c OR d
となりますが、この場合日本語で表すと
a または b かつ c または d
となります。
結果として表示されるのはaであるもの、bでありcでもあるもの、dであるものとなります。
これは2つのORを評価する前にANDを評価するためこのような結果になります。
問題の形にすると
(a OR b) AND c OR d
本来ならANDを評価するところ()があるためa OR bから評価されます。この評価結果をxとすると
x AND c OR dとなります。
次はx AND cが評価されます。
この結果をyとすると、
y OR dとなります。
長文になりましたが以上になります。
わかりにくい書き方になってしまっているかもしれませんが、こちらで理解できなければ先に論理演算について学習すると良いと思います。
コメント
この投稿に対して返信しませんか?
r ren4219
2023/03/17 05:46
長文ありがとうございます。 理解することができました。 ありがとうございます。