婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MySQL中NOT IN填坑之列為null的問題解決

MySQL中NOT IN填坑之列為null的問題解決

熱門標簽:走過哪個省地圖標注 常州網絡外呼系統開發 巫師三血與酒地圖標注 萊西市地圖標注 外呼系統電銷受騙 在哪里申請400電話 400電話申請信用卡 安徽ai電話電銷機器人有效果嗎 銷售語音電話機器人

前一段時間在公司做一個小功能的時候,統計一下某種情況下有多少條數據,然后修改的問題,當時感覺很簡單,寫了一個如下的 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 值,修改如下兩種形式都可以得到預期的結果:

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

或者

select COUNT(*) from t1 where t1.c1 not in (
select t2.c1 from t2 where t2.c1 is not null AND t2.c1 != ''
);

所以都是 null 引起的(為了避免錯誤我把空串也加上了),原因是 not in 的實現原理是,對每一個 t1.c1 和每一個 t2.c1 (括號內的查詢結果)進行不相等比較(!=)。

foreach c1 in t2:
if t1.c1 != c1:
continue
else:
return false
return true

而 SQL 中任意 !=null 的運算結果都是 false,所以如果 t2 中存在一個 null,not in 的查詢永遠都會返回 false,即查詢結果為空。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • 為什么mysql字段要使用NOT NULL
  • 解決mysql使用not in 包含null值的問題
  • 解決從集合運算到mysql的not like找不出NULL的問題
  • MySQL null與not null和null與空值''''''''的區別詳解
  • MySQL中建表時可空(NULL)和非空(NOT NULL)的用法詳解
  • MySQL中可為空的字段設置為NULL還是NOT NULL
  • MySQL查詢空字段或非空字段(is null和not null)
  • mysql not in、left join、IS NULL、NOT EXISTS 效率問題記錄
  • MySQL非空約束(not null)案例講解

標簽:河北 陽江 果洛 來賓 鞍山 黃石 煙臺 赤峰

巨人網絡通訊聲明:本文標題《MySQL中NOT IN填坑之列為null的問題解決》,本文關鍵詞  MySQL,中,NOT,填坑,之,列為,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL中NOT IN填坑之列為null的問題解決》相關的同類信息!
  • 本頁收集關于MySQL中NOT IN填坑之列為null的問題解決的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 长春市| 留坝县| 新乐市| 栾川县| 栖霞市| 射阳县| 阜新市| 灵川县| 元江| 山东省| 加查县| 隆昌县| 湖南省| 富平县| 苍南县| 宝山区| 江孜县| 巴彦淖尔市| 改则县| 乌审旗| 常州市| 新蔡县| 宜黄县| 堆龙德庆县| 固镇县| 民乐县| 汾西县| 大同县| 阿城市| 静宁县| 卓资县| 杭锦后旗| 青浦区| 景泰县| 衡东县| 惠州市| 西贡区| 兰西县| 漾濞| 静乐县| 临颍县|