このページは機械翻訳したものです。
サブクエリーが少なくとも 1 行を返す場合、EXISTS は subqueryTRUE であり、NOT EXISTS は subqueryFALSE です。 例:
SELECT column1 FROM t1 WHERE EXISTS (SELECT * FROM t2);
従来より、EXISTS サブクエリーは SELECT * で始まりますが、SELECT 5 や SELECT column1、あるいはほかの何で始まってもかまいません。 MySQL はこのようなサブクエリー内の SELECT リストを無視するため、何も違いは生まれません。
前の例では、t2 に何らかの行が含まれている場合 (NULL 値以外は何も含まれていない行でも)、EXISTS 条件は TRUE です。 [NOT] EXISTS サブクエリーには、ほぼ常に相互関係が含まれるため、これは実際にはありそうにもない例です。 次に、より現実的な例をいくつか示します。
-
1 つ以上の市に存在するのはどのような種類のお店ですか?
SELECT DISTINCT store_type FROM stores WHERE EXISTS (SELECT * FROM cities_stores WHERE cities_stores.store_type = stores.store_type); -
どの市にも存在しないのはどのような種類のお店ですか?
SELECT DISTINCT store_type FROM stores WHERE NOT EXISTS (SELECT * FROM cities_stores WHERE cities_stores.store_type = stores.store_type); -
すべての市に存在するのはどのような種類のお店ですか?
SELECT DISTINCT store_type FROM stores s1 WHERE NOT EXISTS ( SELECT * FROM cities WHERE NOT EXISTS ( SELECT * FROM cities_stores WHERE cities_stores.city = cities.city AND cities_stores.store_type = stores.store_type));
最後の例は、二重にネストされた NOT EXISTS クエリーです。 つまり、NOT EXISTS 句の中に NOT EXISTS 句が存在します。 これは正式には、「Stores にないお店が含まれている市は存在しますか」? という質問に答えます。 ただし、ネストされた NOT EXISTS が、「x はすべての y に対して TRUE ですか?」という質問に答えるという方が簡単です。
MySQL 8.0.19 以降では、次のように、NOT EXISTS または NOT EXISTS を TABLE とともにサブクエリーで使用することもできます:
SELECT column1 FROM t1 WHERE EXISTS (TABLE t2);
結果は、サブクエリーで WHERE 句を指定せずに SELECT * を使用した場合と同じです。