亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

mysql中not?in隱含陷阱詳解

 更新時間:2022年04月12日 15:53:54   作者:make_888  
NOT?IN?的作用和?IN?恰好相反,NOT?IN?用來判斷表達(dá)式的值是否不存在于給出的列表中;如果不是,返回值為?1,否則返回值為?0,下面這篇文章主要給大家介紹了關(guān)于mysql中not?in隱含陷阱的相關(guān)資料,需要的朋友可以參考下

1、現(xiàn)象

1.1、使用not int 子查詢

SELECT
	* 
FROM
	`users` 
WHERE
	id NOT IN ( SELECT uid FROM role_user )

查詢結(jié)果為:

1.2、結(jié)果對嗎?

當(dāng)然不對

1.2.1、查詢一下role_user的uid結(jié)果

SELECT uid FROM role_user

查詢結(jié)果為:

1.2.2、查詢一下users表的數(shù)據(jù)

SELECT * FROM `users` 

1.2.3、分析查詢結(jié)果

role_user表的數(shù)據(jù)uid只有一個1和null,所以說應(yīng)該能查詢到users表的id=2的數(shù)據(jù)

實際執(zhí)行的sql為:

SELECT
	* 
FROM
	`users` 
WHERE
	id NOT IN ( 1,null )

但是查詢的結(jié)果依然為:

如果我把sql改一下:

SELECT
	* 
FROM
	`users` 
WHERE
	id NOT IN ( 1)

所以可以看到是由于not in 中的結(jié)果有null 導(dǎo)致無法查詢出數(shù)據(jù)的

2、為什么會產(chǎn)生這樣的結(jié)果?

2.1、null屬于什么?

2.2、not in 的底層實現(xiàn)

SELECT
	* 
FROM
	`users` 
WHERE
	id NOT IN ( 1,null )

not in 多個值的實現(xiàn)原理為

SELECT
	* 
FROM
	`users` 
WHERE
	id != 1
	and id != null

第一反應(yīng)是不是覺得是符合的啊?users表的id是主鍵,所以說都不為空值啊

但是為什么會這樣?

我們來執(zhí)行一個sql

select 1 !=null

可以看到查詢結(jié)果為Null,所以說上面的sql里面的id!=null的結(jié)果也是null

由于Null無法參與boolean運算,默認(rèn)為false,所以說上面的條件中and后面的id!=null永遠(yuǎn)是false

3、結(jié)論

說明not in中如果值有null,那么將查詢不到數(shù)據(jù)

到此這篇關(guān)于mysql中not in隱含陷阱的文章就介紹到這了,更多相關(guān)mysql not in隱含陷阱內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • linux下備份MYSQL數(shù)據(jù)庫的方法

    linux下備份MYSQL數(shù)據(jù)庫的方法

    這是一個眾所周知的事實,對你運行中的網(wǎng)站的MySQL數(shù)據(jù)庫備份是極為重要的。
    2010-02-02
  • mysql 索引的基礎(chǔ)操作匯總(四)

    mysql 索引的基礎(chǔ)操作匯總(四)

    這篇文章主要為大家詳細(xì)介紹了mysql 索引的基礎(chǔ)操作匯總,涵蓋了創(chuàng)建和查看索引、刪除索引等操作,感興趣的小伙伴們可以參考一下
    2016-08-08
  • mysqldump進(jìn)行數(shù)據(jù)備份詳解

    mysqldump進(jìn)行數(shù)據(jù)備份詳解

    這篇文章主要介紹了mysqldump進(jìn)行數(shù)據(jù)備份詳解,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以慘一下
    2022-07-07
  • MySQL查詢用戶權(quán)限的方法總結(jié)

    MySQL查詢用戶權(quán)限的方法總結(jié)

    這篇文章主要介紹了MySQL查詢用戶權(quán)限的方法總結(jié)內(nèi)容,需要的朋友們可以參考下。
    2020-03-03
  • mysql 5.7更改數(shù)據(jù)庫的數(shù)據(jù)存儲位置的解決方法

    mysql 5.7更改數(shù)據(jù)庫的數(shù)據(jù)存儲位置的解決方法

    隨著MySQL數(shù)據(jù)庫存儲的數(shù)據(jù)逐漸變大,已經(jīng)將原來的存儲數(shù)據(jù)的空間占滿了,導(dǎo)致mysql已經(jīng)鏈接不上了。所以要給存放的數(shù)據(jù)換個地方,下面小編給大家分享mysql 5.7更改數(shù)據(jù)庫的數(shù)據(jù)存儲位置的解決方法,一起看看吧
    2017-04-04
  • MySQL深分頁問題及三種解決方案

    MySQL深分頁問題及三種解決方案

    本文主要介紹了MySQL深分頁問題及三種解決方案,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • MySQL 5.6主從報錯的實戰(zhàn)記錄

    MySQL 5.6主從報錯的實戰(zhàn)記錄

    這篇文章主要給大家介紹了關(guān)于MySQL 5.6主從報錯的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • 深入mysql并發(fā)插入優(yōu)化詳解

    深入mysql并發(fā)插入優(yōu)化詳解

    本篇文章是對mysql并發(fā)插入優(yōu)化進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • 搞定mysql行轉(zhuǎn)列的7種方法以及列轉(zhuǎn)行

    搞定mysql行轉(zhuǎn)列的7種方法以及列轉(zhuǎn)行

    在MySQL數(shù)據(jù)庫中,有時候我們需要將一列數(shù)據(jù)轉(zhuǎn)化為行數(shù)據(jù),以便更好地進(jìn)行數(shù)據(jù)分析和處理,下面這篇文章主要給大家介紹了關(guān)于搞定mysql行轉(zhuǎn)列的7種方法以及列轉(zhuǎn)行的相關(guān)資料,需要的朋友可以參考下
    2024-03-03
  • MySql 索引、鎖、事務(wù)知識點小結(jié)

    MySql 索引、鎖、事務(wù)知識點小結(jié)

    這篇文章主要介紹了MySql 索引、鎖、事務(wù)知識點,總結(jié)分析了mysql數(shù)據(jù)庫中關(guān)于索引、鎖和事務(wù)的概念、原理、知識點及相關(guān)注意事項,需要的朋友可以參考下
    2019-10-10

最新評論