ホームページ > データベース > mysql チュートリアル > MySQL で「NOT IN」を正しく使用して個別の行を取得する方法は?

MySQL で「NOT IN」を正しく使用して個別の行を取得する方法は?

Susan Sarandon
リリース: 2025-01-13 14:22:42
オリジナル
295 人が閲覧しました

How to Correctly Use `NOT IN` to Retrieve Distinct Rows in MySQL?

MySQL の NOT IN 演算子: 個別の行を選択する際の構文エラーの回避

MySQL の NOT IN 演算子を使用して、列の値が別のテーブルに見つからない行を取得するときに、多くのユーザーが構文エラーに遭遇します。 MySQL は をサポートしますNOT INが、構文は重要です。

クエリ:

<code class="language-sql">SELECT * FROM Table1 WHERE Table1.principal NOT IN Table2.principal</code>
ログイン後にコピー

は正しくないため、構文エラーが発生します。 正しい構文にはサブクエリが必要です:

<code class="language-sql">SELECT * FROM Table1 WHERE Table1.principal NOT IN (SELECT principal FROM Table2)</code>
ログイン後にコピー

括弧を使用して (SELECT principal FROM Table2) を囲むことにより、サブクエリを作成します。 MySQL は、これを Table1.principal と比較する値のセットとして正しく解釈します。この改訂されたクエリは、サブクエリの結果に Table1 値が存在しない principal からのすべての行を効率的に返します。 これにより構文エラーが解決され、期待どおりの結果が得られます。

以上がMySQL で「NOT IN」を正しく使用して個別の行を取得する方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート