MySQL中NOT IN填坑之列為null的問題解決
前一段時間在公司做一個小功能的時候,統(tǒng)計一下某種情況下有多少條數(shù)據(jù),然后修改的問題,當時感覺很簡單,寫了一個如下的 SQL:
SELECT COUNT(*) FROM t1 where tl.c1 not IN (SELECT t2.c1 FROM t2);
預期的結果是:有多少條數(shù)據(jù)在 t1 中,同時不在 t2 中,結果為:0,也就是 t1 中數(shù)據(jù)都在 t2 中,但是很容易就發(fā)現(xiàn)某些數(shù)據(jù)在 t1 中不在 t2 中,所以就感覺很奇怪,這個 SQL 看著也沒問題啊。經(jīng)過一番查詢原來是因為 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 的實現(xiàn)原理是,對每一個 t1.c1 和每一個 t2.c1 (括號內(nèi)的查詢結果)進行不相等比較(!=)。
foreach c1 in t2: if t1.c1 != c1: continue else: return false return true
而 SQL 中任意 !=null 的運算結果都是 false,所以如果 t2 中存在一個 null,not in 的查詢永遠都會返回 false,即查詢結果為空。
總結
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。
相關文章
MySQL 5.7.19安裝目錄下創(chuàng)建my.ini文件的方法
這篇文章給大家簡單介紹了MySQL 5.7.19安裝目錄下創(chuàng)建my.ini文件的方法,需要的的朋友參考下吧2017-08-08MySQL中DATE_FORMATE函數(shù)使用時的注意點
這篇文章主要介紹了MySQL中DATE_FORMATE函數(shù)使用時的注意點,主要是針對其內(nèi)置的字符集使用時需要轉(zhuǎn)換而進行說明,需要的朋友可以參考下2015-05-05阿里云服務器手動實現(xiàn)mysql雙機熱備的兩種方式
阿里云服務器由于不支持keepalive虛擬ip,導致無法通過keepalive來實現(xiàn)mysql的雙機熱備。我們這里要實現(xiàn)阿里云的雙機熱備有兩種方式。感興趣的朋友跟隨小編一起看看吧2019-10-10