設定操作からMySQLへのNULLが見つからない問題を解決する

設定操作からMySQLへのNULLが見つからない問題を解決する

興味深い発見:

合計 1000 件のレコードを含むテーブルがあります。クエリ ステートメントは次のようになります。

#クエリステートメント1
# テーブル内で id に 'A' または 'B' または 'C' が含まれるフィールドを検索します。select * from table1 where id like '%A%' or id like '%B%' or id like '%C%';
#300 件の結果が見つかりました

まあ、クエリは正常で、300 件のレコードがあります。

次に、クエリをランダムに再度入力しました...:

#クエリステートメント2
# テーブル内で id に 'A'、'B'、または 'C' が含まれないフィールドを検索します。select * from table1 where id not like '%A%' and id not like '%B%' and id not like '%C%';
#400 件の結果が見つかりました

さて、400 個のアイテムが見つかりました... 何ですか? !たった400? ? 700個くらいあるんじゃないの? ! !

雷に打たれました。どうしたのでしょうか? ?

論理的には、「ID に 'A' または 'B' または 'C' が含まれるテーブル内のフィールドを検索する」は、「ID に 'A'、'B'、または 'C' が含まれないテーブル内のフィールドを検索する」と同じになります。これは集合演算によって決定されます!

「テーブル内のフィールドのうち、ID に「A」または「B」または「C」が含まれるフィールドを見つけます」>> 次のように考えます >> A∪B∪C

「テーブル内の ID に 'A'、'B'、または 'C' が含まれないフィールドを検索します」>> 次のように考えます >> ∁UA∩∁UB∩∁UC

しかし、演算規則によれば、∁U(A∪B∪C) = ∁UA ∩ ∁UB ∩ ∁UC であることがわかります。

つまり、2 つのクエリ ステートメントの結果は補完的であるべきではないでしょうか? ?理論的には、行の合計は 1000 になるはずですが、なぜ 300 が欠落しているのでしょうか?

それは奇妙ですね。何が悪かったのでしょうか? ?

したがって、クエリ ステートメントを変更します。

#クエリステートメント3
# テーブル内で id に 'A'、'B'、'C' が含まれないフィールドを検索します。select * from table1 where id not in (select * from table1 where id like '%A%' or id like '%B%' or id like '%C%' );
#700 件の結果が見つかりました

はぁ? ?この方法でクエリ ステートメント 1 の補完セットを見つけるにはどうすればよいでしょうか?

クエリ ステートメント 2 とクエリ ステートメント 3 の結果を比較したところ、欠落している 300 件のレコードは id が NULL であったことがわかりました。

つまり、「%A%」とは異なり、NULL レコードを見つけることはできません。

理解した結果、次のことがわかりました。

もう一つの詳しい知識が見つかりました〜

補足: MySQLのクエリ値にnull値がある場合、返されるクエリ結果は常に空になることに注意してください。

これでデータベーステーブルは

次のクエリを使用すると:

ユーザーから*を選択
ユーザー名が 
(
ユーザー名を選択 
ユーザーから
id != 2 の場合
)

この時点では、サブクエリの結果には null 値が含まれているため、結果は常に、ID 2 の予想される行ではなく、空のクエリを返します。

クエリを少し変更することができます。

ユーザーから*を選択
ユーザー名が 
(
ユーザー名を選択 
ユーザーから
id != 2 かつユーザー名が null ではない
)

このとき、空のユーザー名列を除外することで、期待どおりの結果を得ることができます。

上記は私の個人的な経験です。参考になれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。間違いや不備な点がありましたら、遠慮なくご指摘ください。

以下もご興味があるかもしれません:
  • MySQL フィールドで NOT NULL を使用する必要があるのはなぜですか?
  • MySQL で not in を使用して null 値を含める問題を解決する
  • MySQL の null と not null、null と空の値の違いの詳細な説明''''''''
  • MySQL でテーブルを作成するときの NULL と NOT NULL の使用方法の詳細な説明
  • MySQL の NOT IN 充填ピットの NULL 列の問題の解決方法
  • MySQL の null 可能フィールドは NULL に設定する必要がありますか、それとも NOT NULL に設定する必要がありますか?
  • MySQL クエリの空のフィールドまたは空でないフィールド (null または null ではない)
  • mysql は、含まれていない、左結合、IS NULL、NOT EXISTS の効率の問題のレコードです
  • MySQL の null 制約のケースの説明

<<:  ハイパーリンクを開くターゲットのテスト

>>:  Net Core実装プロセス分析のDoc​​kerインストールと展開

推薦する

Reactプロジェクトで要素を使用する方法

React プロジェクトで要素フレームワークを使用するのは今回が初めてです。非常に単純な問題に遭遇し...

VUE ユニアプリテンプレート構文についての簡単な説明

1.v-bind(略称:)コンポーネント プロパティのデータで定義されたデータ変数を使用するか、コン...

MySQL InnoDB インデックス拡張の詳細な説明

インデックス拡張: InnoDB は、プライマリ キー列をそのインデックスに追加することで、各セカン...

nginxリバースプロキシのyum設定の詳細な手順

パート0 背景社内のイントラネットサーバーは直接インターネットにアクセスすることはできませんが、外部...

Centos6.5 に zabbix2.4 をインストールするチュートリアル図

centos-DVD1バージョンシステムの固定IPアドレスは192.168.159.128で、cen...

Iframe 適応高さコードに関する 3 つの議論

B/S システム インターフェースを構築する場合、メイン ページ index.html 内に他のペー...

MySQL 8.0.22 の最新バージョンのダウンロードとインストールの超詳細なチュートリアル (Windows 64 ビット)

目次序文1. 公式サイトからMySQL 8.0.22をダウンロードする2. 環境変数を設定する3. ...

HTML でランダムロールコーラーを実装するためのサンプルコード

この点呼装置は簡易版であり、自動停止の必要性を考慮していないため、点呼を開始した後、停止ボタンをクリ...

DockerはMariaDBのサブライブラリとサブテーブル、および読み書き分離機能を実装します

目次1. はじめに2. 環境整備1. 基本環境3.Mysqlマスタースレーブ構成をインストールする1...

nginxとlvsのメリットとデメリット、そして適切な使用環境

まず最初に、ロード バランシングとは何かについて説明します。ロード バランシングとは、リクエストの内...

Oracle10パーティションとMySQLパーティションの違いの詳細な説明

一般的に使用される Oracle10g パーティションは、範囲 (範囲パーティション)、リスト (リ...

MySQL の連結で複数の一重引用符と三重引用符を使用する際の問題

文字列を動的に連結する場合、文字連結を使用することが多いです。次のような連結の引用符の意味がわかりま...

MySQL NULLがピットを引き起こした

比較演算子でNULLを使用する mysql> 1>NULLを選択します。 +------...

WeChatアプレットはシンプルな手書き署名コンポーネントを実装します

目次背景:必要:効果1. アイデア2. 実装1. ページとスタイル2. 初期化3. クリックすると4...

ログインスライダー検証を実装するJavaScript

この記事では、ログインスライダー検証を実装するためのJavaScriptの具体的なコードを参考までに...