国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

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

2020-01-18 20:38:46
字體:
供稿:網(wǎng)友

前一段時間在公司做一個小功能的時候,統(tǒng)計一下某種情況下有多少條數(shù)據(jù),然后修改的問題,當時感覺很簡單,寫了一個如下的 SQL:

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

預(yù)期的結(jié)果是:有多少條數(shù)據(jù)在 t1 中,同時不在 t2 中,結(jié)果為:0,也就是 t1 中數(shù)據(jù)都在 t2 中,但是很容易就發(fā)現(xiàn)某些數(shù)據(jù)在 t1 中不在 t2 中,所以就感覺很奇怪,這個 SQL 看著也沒問題啊。經(jīng)過一番查詢原來是因為 t2 的 c1 字段包含了 null 值,修改如下兩種形式都可以得到預(yù)期的結(jié)果:

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 的實現(xiàn)原理是,對每一個 t1.c1 和每一個 t2.c1 (括號內(nèi)的查詢結(jié)果)進行不相等比較(!=)。

foreach c1 in t2:if t1.c1 != c1:continueelse:return falsereturn true

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

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對武林網(wǎng)的支持。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 辉县市| 米脂县| 唐山市| 巩义市| 赣榆县| 长泰县| 黄骅市| 江西省| 融水| 府谷县| 安国市| 保康县| 彭阳县| 宁陵县| 从化市| 育儿| 临江市| 湛江市| 淮南市| 虹口区| 清水河县| 布尔津县| 收藏| 上杭县| 凭祥市| 柳州市| 祥云县| 双城市| 北碚区| 连南| 阿拉善左旗| 襄汾县| 洞口县| 黄陵县| 航空| 田阳县| 石嘴山市| 虞城县| 博白县| 西和县| 长海县|