以前、会社で小さな機能に取り組んでいたとき、特定の状況でデータがいくつあるかを数えてから問題を修正しました。当時は非常に単純に思えたので、次の 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 をご愛顧いただき、誠にありがとうございます。 以下もご興味があるかもしれません:
|
<<: WeChatアプレットは左にスワイプしてリスト項目を削除する効果を実現
>>: Docker で MySQL データベースを使用して LAN アクセスを実現する
降順インデックスとは何ですか?インデックスについてはよくご存知かもしれませんが、降順インデックスにつ...
コードは次のようになります。 <!DOCTYPE html> <html> ...
実際の開発では、MySQL の主キーは重複できず、主キーが自動的にインクリメントされることがあります...
目次1. 基本タイプ2. オブジェクトタイプ2.1 配列2.2 タプル2.3 オブジェクト3. 型推...
フレックス レイアウトは間違いなくシンプルで使いやすいです。レイアウトをよりシンプルかつ高速にします...
デプロイされるプロジェクトが増えるにつれて、Tomcat にデプロイされるリリース パッケージも増え...
XHTML タグの紹介<br />おそらく、前のセクションで、XHTML ファイルと通常...
コマンド: mysqlhotcopyこのコマンドは、ファイルをコピーする前にテーブルをロックし、不完...
序文WeChat アプレットを開発する際には、ユーザーの権限が必要なページを使用する必要があることが...
PHP のコンパイル時に -enable-gd-jis-conv オプションを追加することで発生する...
関連記事:初心者が学ぶ HTML タグ (1)初心者は、いくつかの HTML タグを理解することで ...
この記事では、例を使用して、MySQL ストアド プロシージャでの if ステートメントの使用方法を...
目次文章LOCKパラメータアルゴリズムパラメータCOPY TABLE プロセスIN-PLACEプロセ...
目次1. プロジェクトの見通し2. 知識ポイントObject.assign() の使用法filter...
1. プロジェクトwarが保存されているディレクトリを入力しますDockerfileを編集する vi...