mysql中not?in隱含陷阱詳解
1、現(xiàn)象
1.1、使用not int 子查詢(xún)
SELECT * FROM `users` WHERE id NOT IN ( SELECT uid FROM role_user )
查詢(xún)結(jié)果為:
1.2、結(jié)果對(duì)嗎?
當(dāng)然不對(duì)
1.2.1、查詢(xún)一下role_user的uid結(jié)果
SELECT uid FROM role_user
查詢(xún)結(jié)果為:
1.2.2、查詢(xún)一下users表的數(shù)據(jù)
SELECT * FROM `users`
1.2.3、分析查詢(xún)結(jié)果
role_user
表的數(shù)據(jù)uid只有一個(gè)1和null,所以說(shuō)應(yīng)該能查詢(xún)到users
表的id=2的數(shù)據(jù)
實(shí)際執(zhí)行的sql為:
SELECT * FROM `users` WHERE id NOT IN ( 1,null )
但是查詢(xún)的結(jié)果依然為:
如果我把sql改一下:
SELECT * FROM `users` WHERE id NOT IN ( 1)
所以可以看到是由于not in
中的結(jié)果有null
導(dǎo)致無(wú)法查詢(xún)出數(shù)據(jù)的
2、為什么會(huì)產(chǎn)生這樣的結(jié)果?
2.1、null屬于什么?
2.2、not in 的底層實(shí)現(xiàn)
SELECT * FROM `users` WHERE id NOT IN ( 1,null )
not in 多個(gè)值的實(shí)現(xiàn)原理為
SELECT * FROM `users` WHERE id != 1 and id != null
第一反應(yīng)是不是覺(jué)得是符合的???users
表的id是主鍵,所以說(shuō)都不為空值啊
但是為什么會(huì)這樣?
我們來(lái)執(zhí)行一個(gè)sql
select 1 !=null
可以看到查詢(xún)結(jié)果為Null,所以說(shuō)上面的sql里面的id!=null
的結(jié)果也是null
由于Null無(wú)法參與boolean運(yùn)算,默認(rèn)為false,所以說(shuō)上面的條件中and后面的id!=null永遠(yuǎn)是false
3、結(jié)論
說(shuō)明not in中如果值有null,那么將查詢(xún)不到數(shù)據(jù)
到此這篇關(guān)于mysql中not in隱含陷阱的文章就介紹到這了,更多相關(guān)mysql not in隱含陷阱內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
linux下備份MYSQL數(shù)據(jù)庫(kù)的方法
這是一個(gè)眾所周知的事實(shí),對(duì)你運(yùn)行中的網(wǎng)站的MySQL數(shù)據(jù)庫(kù)備份是極為重要的。2010-02-02mysqldump進(jìn)行數(shù)據(jù)備份詳解
這篇文章主要介紹了mysqldump進(jìn)行數(shù)據(jù)備份詳解,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以慘一下2022-07-07MySQL查詢(xún)用戶(hù)權(quán)限的方法總結(jié)
這篇文章主要介紹了MySQL查詢(xún)用戶(hù)權(quán)限的方法總結(jié)內(nèi)容,需要的朋友們可以參考下。2020-03-03mysql 5.7更改數(shù)據(jù)庫(kù)的數(shù)據(jù)存儲(chǔ)位置的解決方法
隨著MySQL數(shù)據(jù)庫(kù)存儲(chǔ)的數(shù)據(jù)逐漸變大,已經(jīng)將原來(lái)的存儲(chǔ)數(shù)據(jù)的空間占滿(mǎn)了,導(dǎo)致mysql已經(jīng)鏈接不上了。所以要給存放的數(shù)據(jù)換個(gè)地方,下面小編給大家分享mysql 5.7更改數(shù)據(jù)庫(kù)的數(shù)據(jù)存儲(chǔ)位置的解決方法,一起看看吧2017-04-04MySQL 5.6主從報(bào)錯(cuò)的實(shí)戰(zhàn)記錄
這篇文章主要給大家介紹了關(guān)于MySQL 5.6主從報(bào)錯(cuò)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03搞定mysql行轉(zhuǎn)列的7種方法以及列轉(zhuǎn)行
在MySQL數(shù)據(jù)庫(kù)中,有時(shí)候我們需要將一列數(shù)據(jù)轉(zhuǎn)化為行數(shù)據(jù),以便更好地進(jìn)行數(shù)據(jù)分析和處理,下面這篇文章主要給大家介紹了關(guān)于搞定mysql行轉(zhuǎn)列的7種方法以及列轉(zhuǎn)行的相關(guān)資料,需要的朋友可以參考下2024-03-03MySql 索引、鎖、事務(wù)知識(shí)點(diǎn)小結(jié)
這篇文章主要介紹了MySql 索引、鎖、事務(wù)知識(shí)點(diǎn),總結(jié)分析了mysql數(shù)據(jù)庫(kù)中關(guān)于索引、鎖和事務(wù)的概念、原理、知識(shí)點(diǎn)及相關(guān)注意事項(xiàng),需要的朋友可以參考下2019-10-10