前一段時(shí)間在公司做一個(gè)小功能的時(shí)候,統(tǒng)計(jì)一下某種情況下有多少條數(shù)據(jù),然后修改的問題,當(dāng)時(shí)感覺很簡單,寫了一個(gè)如下的 SQL:
SELECT COUNT(*) FROM t1 where tl.c1 not IN (SELECT t2.c1 FROM t2);
預(yù)期的結(jié)果是:有多少條數(shù)據(jù)在 t1 中,同時(shí)不在 t2 中,結(jié)果為:0,也就是 t1 中數(shù)據(jù)都在 t2 中,但是很容易就發(fā)現(xiàn)某些數(shù)據(jù)在 t1 中不在 t2 中,所以就感覺很奇怪,這個(gè) SQL 看著也沒問題啊。經(jīng)過一番查詢原來是因?yàn)?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 引起的(為了避免錯(cuò)誤我把空串也加上了),原因是 not in 的實(shí)現(xiàn)原理是,對每一個(gè) t1.c1 和每一個(gè) t2.c1 (括號內(nèi)的查詢結(jié)果)進(jìn)行不相等比較(!=)。
foreach c1 in t2:
if t1.c1 != c1:
continue
else:
return false
return true
而 SQL 中任意 !=null 的運(yùn)算結(jié)果都是 false,所以如果 t2 中存在一個(gè) null,not in 的查詢永遠(yuǎn)都會返回 false,即查詢結(jié)果為空。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對腳本之家的支持。
您可能感興趣的文章:- 為什么mysql字段要使用NOT NULL
- 解決mysql使用not in 包含null值的問題
- 解決從集合運(yùn)算到mysql的not like找不出NULL的問題
- MySQL null與not null和null與空值''''''''的區(qū)別詳解
- MySQL中建表時(shí)可空(NULL)和非空(NOT NULL)的用法詳解
- MySQL中可為空的字段設(shè)置為NULL還是NOT NULL
- MySQL查詢空字段或非空字段(is null和not null)
- mysql not in、left join、IS NULL、NOT EXISTS 效率問題記錄
- MySQL非空約束(not null)案例講解