a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 數據庫 > MySQL > 正文

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

2020-01-18 20:38:46
字體:
來源:轉載
供稿:網友

前一段時間在公司做一個小功能的時候,統計一下某種情況下有多少條數據,然后修改的問題,當時感覺很簡單,寫了一個如下的 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:continueelse:return falsereturn true

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

總結

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产精品三级久久久久久电影 | 在线精品一区 | 久久久一区二区三区 | 国产精品久久久久久久久久久新郎 | 99国产精品99久久久久久 | 六月丁香在线观看 | 日本免费一区二区三区 | 欧美激情视频一区二区三区在线播放 | 欧美在线a | 欧美一区永久视频免费观看 | 欧美视频在线免费 | 国产在线一二 | 欧美成人区 | 国产第一二区 | 欧洲精品久久久 | 日韩欧美精品 | 亚洲黄色av网站 | 精品一区在线 | 日韩精品一区二区三区四区视频 | 91久久看片 | 羞羞视频在线免费 | 日本在线观看视频一区 | 午夜一级黄色片 | a级毛片基地 | 免费一区 | 国产羞羞视频在线观看 | 久久大 | 99精品国产一区二区 | 农村妇女毛片精品久久久 | 青青草免费在线 | 午夜看片在线观看 | 久久22 | 久久一二区 | 日韩欧美高清dvd碟片 | 色噜噜色狠狠 | 操视频网站 | 成人在线免费 | 人人爽人人做 | 久久久av| 国产精品国产三级国产aⅴ中文 | 成人一区二区三区在线观看 |