欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2019年11月25日 08:36:48   作者:Bridge Li  
這篇文章主要給大家介紹了關(guān)于MySQL中NOT IN填坑之列為null的問題解決的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧

前一段時(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 (括號(hào)內(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)都會(huì)返回 false,即查詢結(jié)果為空。

總結(jié)

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

相關(guān)文章

  • mysql Myisamchk小工具使用手冊

    mysql Myisamchk小工具使用手冊

    Myisamchk是MyISAM表維護(hù)的一個(gè)非常實(shí)用的工具。可以使用myisamchk實(shí)用程序來獲得有關(guān)數(shù)據(jù)庫表的信息或檢查、修復(fù)、優(yōu)化他們。myisamchk適用MyISAM表(對應(yīng).MYI和.MYD文件的表)。
    2008-10-10
  • 如何開啟mysql中的嚴(yán)格模式

    如何開啟mysql中的嚴(yán)格模式

    這篇文章介紹了如何開啟mysql中的嚴(yán)格模式,有需要的朋友可以參考一下
    2013-09-09
  • MySQL用戶權(quán)限管理詳解

    MySQL用戶權(quán)限管理詳解

    這篇文章主要為大家詳細(xì)介紹了MySQL用戶權(quán)限管理的相關(guān)資料,感興趣的小伙伴們可以參考一下
    2016-07-07
  • Mysql數(shù)據(jù)庫錯(cuò)誤代碼中文詳細(xì)說明

    Mysql數(shù)據(jù)庫錯(cuò)誤代碼中文詳細(xì)說明

    在mysql開發(fā)中出現(xiàn)錯(cuò)誤代碼各種各樣,下面我來給大家收集常用見的mysql使用過程中出錯(cuò)代碼的中文說明,希望些文章對各位朋友有所幫助了
    2013-08-08
  • MySQL 5.7.19安裝目錄下創(chuàng)建my.ini文件的方法

    MySQL 5.7.19安裝目錄下創(chuàng)建my.ini文件的方法

    這篇文章給大家簡單介紹了MySQL 5.7.19安裝目錄下創(chuàng)建my.ini文件的方法,需要的的朋友參考下吧
    2017-08-08
  • MySQL中DATE_FORMATE函數(shù)使用時(shí)的注意點(diǎn)

    MySQL中DATE_FORMATE函數(shù)使用時(shí)的注意點(diǎn)

    這篇文章主要介紹了MySQL中DATE_FORMATE函數(shù)使用時(shí)的注意點(diǎn),主要是針對其內(nèi)置的字符集使用時(shí)需要轉(zhuǎn)換而進(jìn)行說明,需要的朋友可以參考下
    2015-05-05
  • 阿里云服務(wù)器手動(dòng)實(shí)現(xiàn)mysql雙機(jī)熱備的兩種方式

    阿里云服務(wù)器手動(dòng)實(shí)現(xiàn)mysql雙機(jī)熱備的兩種方式

    阿里云服務(wù)器由于不支持keepalive虛擬ip,導(dǎo)致無法通過keepalive來實(shí)現(xiàn)mysql的雙機(jī)熱備。我們這里要實(shí)現(xiàn)阿里云的雙機(jī)熱備有兩種方式。感興趣的朋友跟隨小編一起看看吧
    2019-10-10
  • MySQL字符集不一致導(dǎo)致索引失效的解決辦法

    MySQL字符集不一致導(dǎo)致索引失效的解決辦法

    本文分析了一個(gè)由于字符集不一致,導(dǎo)致增加了索引但是無法使用的案例,通過索引進(jìn)行查找時(shí)需要進(jìn)行數(shù)據(jù)的比較,字符集不一致時(shí)需要使用 convert 函數(shù)進(jìn)行轉(zhuǎn)換,從而導(dǎo)致索引失效,文中有詳細(xì)的解決辦法,需要的朋友可以參考下
    2024-04-04
  • MySQL數(shù)值類型溢出的處理方法

    MySQL數(shù)值類型溢出的處理方法

    這篇文章主要給大家介紹了關(guān)于MySQL數(shù)值類型溢出的處理方法,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • mysql alter語句用法實(shí)例

    mysql alter語句用法實(shí)例

    這里簡單分享幾個(gè)mysql alter語句用法,方便大家使用
    2013-02-02

最新評論