濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > 在SQL中該如何處理NULL值

在SQL中該如何處理NULL值

熱門標(biāo)簽:外呼系統(tǒng)會(huì)封嗎 萬(wàn)利達(dá)綜合醫(yī)院地圖標(biāo)注點(diǎn) 股票配資電銷機(jī)器人 武漢AI電銷機(jī)器人 南京電銷外呼系統(tǒng)哪家好 地圖標(biāo)注如何弄全套標(biāo) 實(shí)體店地圖標(biāo)注怎么標(biāo) 電銷機(jī)器人 深圳 在電子版地圖標(biāo)注要收費(fèi)嗎

在日常使用數(shù)據(jù)庫(kù)時(shí),你在意過(guò)NULL值么?

其實(shí),NULL值在數(shù)據(jù)庫(kù)中是一個(gè)很特殊且有趣的存在,下面我們一起來(lái)看看吧;

小伙伴想精準(zhǔn)查找自己想看的MySQL文章?喏 → MySQL專欄目錄 | 點(diǎn)擊這里

在查詢數(shù)據(jù)庫(kù)時(shí),如果你想知道一個(gè)列(例如:用戶注冊(cè)年限 USER_AGE)是否為 NULL,SQL 查詢語(yǔ)句該怎么寫呢?

是這樣:

SELECT * FROM TABLE WHERE USER_AGE = NULL

還是這樣?

SELECT * FROM TABLE WHERE USER_AGE IS NULL

當(dāng)然,正確的寫法應(yīng)該是第二種(WHERE USER_AGE IS NULL)。

但為什么要這樣寫呢?在進(jìn)行數(shù)據(jù)庫(kù)數(shù)據(jù)比較操作時(shí),我們不會(huì)使用“IS”關(guān)鍵詞,不是嗎?

 

一臉懵逼

例如,如果我們想要知道一個(gè)列的值是否等于 1,WHERE 語(yǔ)句是這樣的:

WHERE USER_AGE = 1

那為什么 NULL 值要用 IS 關(guān)鍵字呢?為什么要以這種方式來(lái)處理 NULL?

因?yàn)椋?strong>在 SQL 中,NULL 表示“未知”。也就是說(shuō),NULL 值表示的是“未知”的值。

NULL = 未知;

在大多數(shù)數(shù)據(jù)庫(kù)中,NULl 和空字符串是有區(qū)別的。

但并不是所有數(shù)據(jù)庫(kù)都這樣,例如,Oracle 就不支持空字符串,它會(huì)把空字符串自動(dòng)轉(zhuǎn)成 NULL 值。

在其他大多數(shù)數(shù)據(jù)庫(kù)里,NULL 值和字符串的處理方式是不一樣的:

  • 空字符("")串雖然表示“沒(méi)有值”,但這個(gè)值是已知的。
  • NULL 表示 “未知值”,這個(gè)值是未知的。

這就好比我問(wèn)了一個(gè)問(wèn)題:“川建國(guó)的小名叫什么?”

有人會(huì)回答說(shuō):“我不知道川建國(guó)的小名是什么”。對(duì)于這種情況,可以在數(shù)據(jù)庫(kù)中使用Nickname列來(lái)表示川建國(guó)的小名,而這一列的值為 NULL。

也有人會(huì)回答說(shuō):“川建國(guó)沒(méi)有小名。他的父母沒(méi)有給他取小名,大家雖然一直叫他川二狗,但是我知道川建國(guó)確實(shí)沒(méi)有小名”。對(duì)于這種情況,Nickname列應(yīng)該是一個(gè)空字符串("")。

Oracle 比較特殊,兩個(gè)值都使用 NULL 來(lái)表示,而其他大多數(shù)數(shù)據(jù)庫(kù)會(huì)區(qū)分對(duì)待。

但只要記住 NULL 表示的是一個(gè)未知的值,那么在寫 SQL 查詢語(yǔ)句時(shí)就會(huì)得心應(yīng)手。

例如,如果你有一個(gè)這樣的查詢語(yǔ)句:

SELECT * FROM SOME_TABLE WHERE 1 = 1

這個(gè)查詢會(huì)返回所有的行(假設(shè) SOME_TABLE 不是空表),因?yàn)楸磉_(dá)式“1=1”一定為 true。

如果我這樣寫:

SELECT * FROM SOME_TABLE WHERE 1 = 0

表達(dá)式“1=0”是 false,這個(gè)查詢語(yǔ)句不會(huì)返回任何數(shù)據(jù)。

但如果我寫成這樣:

SELECT * FROM SOME_TABLE WHERE 1 = NULL

這個(gè)時(shí)候,數(shù)據(jù)庫(kù)不知道這兩個(gè)值(1 和 NULL)是否相等,因此會(huì)認(rèn)定為“NULL”或“未知”,所以它也不會(huì)返回任何數(shù)據(jù)。

  三元邏輯

SQL 查詢語(yǔ)句中的 WHERE 一般會(huì)有三種結(jié)果:

  • 它可以是 true(這個(gè)時(shí)候會(huì)返回?cái)?shù)據(jù));
  • 它可以是 false(這個(gè)時(shí)候不會(huì)返回?cái)?shù)據(jù));
  • 它也可以是 NULL 或未知(這個(gè)時(shí)候也不會(huì)返回?cái)?shù)據(jù));

你可能會(huì)想:“既然這樣,那我為什么要去關(guān)心是 false 還是 NULL?它們不是都不會(huì)返回?cái)?shù)據(jù)嗎?”

接下來(lái),我來(lái)告訴你在哪些情況下會(huì)有問(wèn)題:我們來(lái)看看 NOT( ) 方法。

假設(shè)有這樣的一個(gè)查詢語(yǔ)句:

SELECT * FROM SOME_TABLE WHERE NOT(1 = 1)

數(shù)據(jù)庫(kù)首先會(huì)計(jì)算 1=1,這個(gè)顯然是 true。

接著,數(shù)據(jù)庫(kù)會(huì)應(yīng)用 NOT() 條件,所以 WHERE 返回 false。

所以,上面的查詢不會(huì)返回任何數(shù)據(jù)。

但如果把語(yǔ)句改成這樣:

SELECT * FROM SOME_TABLE WHERE NOT(1 = 0)


數(shù)據(jù)庫(kù)首先會(huì)計(jì)算 1=0,這個(gè)肯定是 false。

接著,數(shù)據(jù)庫(kù)應(yīng)用 NOT() 條件,這樣就得到相反的結(jié)果,變成了 true。

所以,這個(gè)語(yǔ)句會(huì)返回?cái)?shù)據(jù)。

但如果把語(yǔ)句再改成下面這樣呢?

SELECT * FROM SOME_TABLE WHERE NOT(1 = NULL)

數(shù)據(jù)庫(kù)首先計(jì)算 1=NULL,它不知道 1 是否等于 NULL,因?yàn)樗恢?NULL 的值是什么。

所以,這個(gè)計(jì)算不會(huì)返回 true,也不會(huì)返回 false,它會(huì)返回一個(gè) NULL。

接下來(lái),NOT() 會(huì)繼續(xù)解析上一個(gè)計(jì)算返回的結(jié)果。

當(dāng) NOT() 遇到 NULL,它會(huì)生成另一個(gè) NULL。未知的相反面是另一個(gè)未知。

所以,對(duì)于這兩個(gè)查詢:

SELECT * FROM SOME_TABLE WHERE NOT(1 = NULL)
SELECT * FROM SOME_TABLE WHERE 1 = NULL

都不會(huì)返回?cái)?shù)據(jù),盡管它們是完全相反的。

NULL 和 NOT IN
如果我有這樣的一個(gè)查詢語(yǔ)句:

SELECT * FROM TABLE WHERE 1 IN (1, 2, 3, 4, NULL)

很顯然,WHERE 返回 true,這個(gè)語(yǔ)句將返回?cái)?shù)據(jù),因?yàn)?1 在括號(hào)列表里是存在的。

但如果這么寫:

SELECT * FROM SOME_TABLE WHERE 1 NOT IN (1, 2, 3, 4, NULL)

很顯然,WHERE 返回 false,這個(gè)查詢不會(huì)返回?cái)?shù)據(jù),因?yàn)?1 在括號(hào)列表里存在,但我們說(shuō)的是“NOT IN”。

但如果我們把語(yǔ)句改成這樣呢?

SELECT * FROM SOME_TABLE WHERE 5 NOT IN (1, 2, 3, 4, NULL)

這里的 WHERE 不會(huì)返回?cái)?shù)據(jù),因?yàn)樗慕Y(jié)果不是 true。數(shù)字 5 在括號(hào)列表里可能不存在,也可能存在,因?yàn)楫?dāng)中有一個(gè) NULL 值(數(shù)據(jù)庫(kù)不知道 NULL 的值是什么)。

這個(gè) WHERE 會(huì)返回 NULL,所以整個(gè)查詢不會(huì)返回任何數(shù)據(jù)。

希望大家現(xiàn)在都清楚該怎么在 SQL 語(yǔ)句中處理 NULL 值了。更多相關(guān)SQL處理NULL值內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • sqlserver 不能將值NULL插入列id(列不允許有空值解決)
  • mysql中將null值轉(zhuǎn)換為0的語(yǔ)句
  • MySQL中對(duì)于NULL值的理解和使用教程
  • 在SQL Server中使用ISNULL執(zhí)行空值判斷查詢
  • 詳解MySQL中的NULL值
  • sql 語(yǔ)句中的 NULL值
  • MySQL NULL 值處理實(shí)例詳解
  • SQL 中 NULL值測(cè)試代碼

標(biāo)簽:濟(jì)源 武威 泰安 汕頭 安徽 臺(tái)州 濟(jì)寧 廣東

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《在SQL中該如何處理NULL值》,本文關(guān)鍵詞  在,SQL,中該,如何,處理,NULL,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《在SQL中該如何處理NULL值》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于在SQL中該如何處理NULL值的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    青岛市| 望江县| 乌鲁木齐县| 玉树县| 达拉特旗| 颍上县| 荥阳市| 双城市| 高陵县| 亳州市| 威宁| 邵东县| 土默特左旗| 崇文区| 洛扎县| 清水河县| 江油市| 隆子县| 泸西县| 汝城县| 江川县| 库车县| 盐城市| 济宁市| 台安县| 海宁市| 泾源县| 方山县| 天津市| 闻喜县| 伊宁县| 昆明市| 襄垣县| 宿州市| 新巴尔虎右旗| 黄山市| 永新县| 太原市| 察哈| 项城市| 大理市|