MySQL の NOT IN 充填ピットの NULL 列の問題の解決方法

MySQL の NOT IN 充填ピットの NULL 列の問題の解決方法

以前、会社で小さな機能に取り組んでいたとき、特定の状況でデータがいくつあるかを数えてから問題を修正しました。当時は非常に単純に思えたので、次の SQL を書きました。

SELECT COUNT(*) FROM t1 where tl.c1 not IN (SELECT t2.c1 FROM t2);

期待される結果は、t1 にあって t2 にないデータがいくつあるかということです。結果は 0 で、つまり t1 のすべてのデータが t2 にあります。ただし、一部のデータが t1 にあるのに t2 にはないことは簡単にわかるので、非常に奇妙に感じます。この SQL は問題ないようです。調べてみると、t2 の c1 フィールドに null 値が含まれていることがわかりました。次の 2 つの形式に変更すると、期待どおりの結果が得られます。

SELECT COUNT(*) FROM t1 LEFT JOIN t2 ON t1.c1 = t2.c1 WHERE t2.c1 IS NULL OR t2.c1 = '';

または

t1.c1が(に含まれない)からCOUNT(*)を選択します。
t2.c1 が null ではなく、t2.c1 != '' の場合、t2 から t2.c1 を選択します。
);

つまり、すべて null が原因です (エラーを回避するために空の文字列も追加しました)。その理由は、not in の実装原則は、各 t1.c1 と各 t2.c1 (かっこ内のクエリ結果) を比較して不等 (!=) であるかどうかを確認することだからです。

c1 を t2 で繰り返し実行:
t1.c1 != c1 の場合:
続く
それ以外:
偽を返す
真を返す

SQL では、!=null のすべての演算結果は false になるため、t2 に null がある場合、not in のクエリは常に false を返します。つまり、クエリ結果は空になります。

要約する

以上がこの記事の全内容です。この記事の内容が皆様の勉強や仕事に何らかの参考学習価値をもたらすことを願います。123WORDPRESS.COM をご愛顧いただき、誠にありがとうございます。

以下もご興味があるかもしれません:
  • MySQLのNULL値の詳しい説明
  • MySQL NULL値処理例の詳細な説明
  • MySQL NULLデータ変換方法(必読)
  • MySQL の NULL 値に関する体験談と分析チュートリアルシリーズ

<<:  WeChatアプレットは左にスワイプしてリスト項目を削除する効果を実現

>>:  Docker で MySQL データベースを使用して LAN アクセスを実現する

推薦する

この記事では、jsのデータ型とデータ構造の世界を紹介します。

目次1. 動的型付けとは何ですか? 2. データ型2.1 プリミティブ型 (6 つのプリミティブ型、...

MySQLを監視するためのbinlogログ解析ツールの詳しい説明:Canal

Canal は、Java を使用して開発された Alibaba のオープンソース プロジェクトです...

5分でWebRTCビデオチャットを構築する

前回の記事では、Ubuntu 上の webrtc ベースの多人数ビデオチャット サービスの詳細なコー...

Linux での wget コマンドの基本的な使い方

目次序文1. wgetを使用して単一のファイルをダウンロードする2. wget -Oを使用してダウン...

MySQL 5.7 における基本的な JSON 操作ガイド

序文プロジェクトのニーズにより、ストレージ フィールドは JSON 形式で保存されます。プロジェクト...

CD コマンドを使わずに Linux でディレクトリ/フォルダに入る方法

ご存知のとおり、cd コマンドがないと、Linux でディレクトリを切り替えることはできません。それ...

Linux 上の Tomcat で MySQL にデータを挿入するときに中国語の文字化けが発生する問題を解決する

1. 問題Windows 上の Eclipse を使用して開発されたプロジェクトは Windows ...

MySQL実践ウィンドウ関数SQL分析クラスの生徒のテストの成績と生活費

目次1. 背景2. テーブル作成ステートメントとデータ挿入テーブルを作成するデータの挿入3. ウィン...

Nginx フォワード プロキシとリバース プロキシ、および負荷分散機能の構成コード例

この記事は主に、Nginx のフォワード プロキシとリバース プロキシ、および負荷分散機能の設定コー...

Centos6.9 インストール Mysql5.7.18 ステップ記録

インストール手順 rpm -ivh mysql-コミュニティ-共通-5.7.18-1.el7.x86...

mysql5.7.21 の異常起動を修正する方法

同僚から、停電のため MySQL インスタンスを起動できないという報告がありました。 innodb_...

タイムスタンプの差を計算するSQLメソッド

タイムスタンプの差を計算するSQLメソッド概要場合によっては、特定のレコードを時間で検索する必要があ...

MySQL データベースの基礎 SQL ウィンドウ関数の例の分析チュートリアル

目次導入導入集計関数 + over()ソート関数 + over() ntile() 関数 + ove...

CSS3 フィルター属性の使い方の紹介

1. はじめにフロントエンドページのアニメーション効果を記述する場合、filter 属性は多かれ少な...