MySQL "NOT IN" 3 つのテーブルのクエリ
gt;3 つのテーブルを操作する場合、クエリで "NOT IN" 演算子を使用する特に NULL 値を扱う場合には、問題が発生する可能性があります。この記事では、「NOT IN」の使用に関連するリスクを示し、代替解決策を提案します。
gt;問題
提供されたクエリは、Grade と 2 つのテーブルを比較しようとしています。評価。評価に存在しないグレードのレコードを識別します。ただし、指定された名前 (「JOHN」) が評価に存在しない場合、クエリは出力を返しません。
解決策
この問題に対処するには、データのフィルタリングに使用されるサブクエリに NULL 値が含まれる可能性がある場合は、「NOT IN」の使用を避けてください。代わりに、「NOT EXISTS」または左結合の使用を検討してください。
「NOT IN」を使用する潜在的な危険性を説明してみましょう:
SQL 「入っていない」危険
サンプル データを含む mStatus テーブルと people テーブル:
create table mStatus ( id int auto_increment primary key, status varchar(10) not null ); insert mStatus (status) values ('single'),('married'),('divorced'),('widow'); create table people ( id int auto_increment primary key, fullName varchar(100) not null, status varchar(10) null );
Chunk1:
truncate table people; insert people (fullName,`status`) values ('John Henry','single'); select * from mstatus where `status` not in (select status from people);
予想される出力: 3 行
Chunk2:
truncate table people; insert people (fullName,`status`) values ('John Henry','single'),('Kim Billings',null); select * from mstatus where status not in (select status from people);
予期しない出力: 0 行
2 番目SQL の 3 値ロジックにより、chunk は予期せず行を返しません。サブクエリに NULL 値が含まれている場合、「NOT IN」式が UNKNOWN と評価される可能性があり、その結果、すべての行が除外されます。
代替手段select s.status
from mstatus s
left join people p
on p.status=s.status
where p.status is null
これを解決するにはこの問題が発生した場合は、「LEFT JOIN」または「NOT」を使用してください。 EXISTS":select s.status
from mstatus s
where not exists (select 1 from people where people.status=s.status)
これらの代替ソリューションは、NULL 値を正しく処理し、必要な出力を提供します。以上がMySQL の「NOT IN」が 3 つのテーブルと NULL で失敗するのはなぜですか? より良い代替案は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この記事では、DockerのMySQLメモリ使用量を最適化することを調査します。 監視手法(Docker統計、パフォーマンススキーマ、外部ツール)および構成戦略について説明します。 これらには、Dockerメモリの制限、スワッピング、およびcgroupsが含まれます

この記事では、MySQLの「共有ライブラリを開くことができない」エラーについて説明します。 この問題は、必要な共有ライブラリ(.so/.dllファイル)を見つけることができないMySQLの障害に起因しています。ソリューションには、システムのパッケージMを介してライブラリのインストールを確認することが含まれます。

この記事では、MySQLのAlter Tableステートメントを使用して、列の追加/ドロップ、テーブル/列の名前の変更、列データ型の変更など、テーブルを変更することについて説明します。

この記事では、PHPMyAdminの有無にかかわらず、LinuxにMySQLを直接インストールするのとPodmanコンテナを使用します。 それは、各方法のインストール手順を詳述し、孤立、携帯性、再現性におけるポッドマンの利点を強調しますが、

この記事では、自己完結型のサーバーレスリレーショナルデータベースであるSQLiteの包括的な概要を説明します。 SQLiteの利点(シンプルさ、移植性、使いやすさ)と短所(同時性の制限、スケーラビリティの課題)を詳しく説明しています。 c

このガイドは、HomeBrewを使用してMacOSに複数のMySQLバージョンをインストールおよび管理することを示しています。 Homebrewを使用して設置を分離し、紛争を防ぐことを強調しています。 この記事では、インストール、開始/停止サービス、および最高のPRAを詳述しています

記事では、証明書の生成と検証を含むMySQL用のSSL/TLS暗号化の構成について説明します。主な問題は、セルフ署名証明書のセキュリティへの影響を使用することです。[文字カウント:159]

記事では、MySQLワークベンチやPHPMyAdminなどの人気のあるMySQL GUIツールについて説明し、初心者と上級ユーザーの機能と適合性を比較します。[159文字]


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

Dreamweaver Mac版
ビジュアル Web 開発ツール

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境
