問題
"商品" 表、"在庫" 表に対する次の SQL 文の結果と同じ結果が得られる SQL 文はどれか。ここで、下線部は主キーを表す。 SELECT 商品番号 FROM 商品 WHERE 商品番号 NOT IN (SELECT 商品番号 FROM 在庫)

選択肢
- 1SELECT 商品番号 FROM 在庫 WHERE EXISTS (SELECT 商品番号 FROM 商品)
- 2SELECT 商品番号 FROM 在庫 WHERE NOT EXISTS (SELECT 商品番号 FROM 商品)
- 3SELECT 商品番号 FROM 商品 WHERE EXISTS (SELECT 商品番号 FROM 在庫 WHERE 商品.商品番号 = 在庫.商品番号)
- 4SELECT 商品番号 FROM 商品 WHERE NOT EXISTS (SELECT 商品番号 FROM 在庫 WHERE 商品.商品番号 = 在庫.商品番号)
正解
4. SELECT 商品番号 FROM 商品 WHERE NOT EXISTS (SELECT 商品番号 FROM 在庫 WHERE 商品.商品番号 = 在庫.商品番号)
詳しい解説を見る解説を閉じる
解説
元の SQL は「在庫表に存在しない商品番号を商品表から取り出す」もので、在庫にない商品を求めている。これと同じ結果は、相関副問合せで「在庫表に対応する商品番号が存在しない(NOT EXISTS)」商品を商品表から選ぶエで得られる。よって「エ」が正しい。NOT IN と NOT EXISTS は同等の結果を返す。(出典: 平成26年度 春期 基本情報技術者試験 午前 問28)
一問一答
科目A 180問+科目B 60問