天天看點

SQL 中的 NULL 原來是這麼回事,有意思!

其實,NULL值在資料庫中是一個很特殊且有趣的存在,下面我們一起來看看吧;

在查詢資料庫時,如果你想知道一個列(例如:使用者注冊年限 USER_AGE)是否為 NULL,SQL 查詢語句該怎麼寫呢?

是這樣:

SELECT * FROM TABLE WHERE USER_AGE = NULL

還是這樣?

SELECT * FROM TABLE WHERE USER_AGE IS NULL

當然,正确的寫法應該是第二種(WHERE USER_AGE IS NULL)。

但為什麼要這樣寫呢?在進行資料庫資料比較操作時,我們不會使用“IS”關鍵詞,不是嗎?

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

WHERE USER_AGE = 1

那為什麼 NULL 值要用 IS 關鍵字呢?為什麼要以這種方式來處理 NULL?

因為,在 SQL 中,NULL 表示“未知”。也就是說,NULL 值表示的是“未知”的值。

NULL = 未知;

在大多數資料庫中,NULl 和空字元串是有差別的。

但并不是所有資料庫都這樣,例如,Oracle 就不支援空字元串,它會把空字元串自動轉成 NULL 值。

在其他大多數資料庫裡,NULL 值和字元串的處理方式是不一樣的:

空字元("")串雖然表示“沒有值”,但這個值是已知的。

NULL 表示 “未知值”,這個值是未知的。

Oracle 比較特殊,兩個值都使用 NULL 來表示,而其他大多數資料庫會區分對待。

但隻要記住 NULL 表示的是一個未知的值,那麼在寫 SQL 查詢語句時就會得心應手。

例如,如果你有一個這樣的查詢語句:

SELECT * FROM SOME_TABLE WHERE 1 = 1

這個查詢會傳回所有的行(假設 SOME_TABLE 不是空表),因為表達式“1=1”一定為 true。

如果我這樣寫:

SELECT * FROM SOME_TABLE WHERE 1 = 0

表達式“1=0”是 false,這個查詢語句不會傳回任何資料。

但如果我寫成這樣:

SELECT * FROM SOME_TABLE WHERE 1 = NULL

這個時候,資料庫不知道這兩個值(1 和 NULL)是否相等,是以會認定為“NULL”或“未知”,是以它也不會傳回任何資料。

三元邏輯

SQL 查詢語句中的 WHERE 一般會有三種結果:

它可以是 true(這個時候會傳回資料);

它可以是 false(這個時候不會傳回資料);

它也可以是 NULL 或未知(這個時候也不會傳回資料);

SQL 中的 NULL 原來是這麼回事,有意思!

你可能會想:“既然這樣,那我為什麼要去關心是 false 還是 NULL?它們不是都不會傳回資料嗎?”

接下來,我來告訴你在哪些情況下會有問題:我們來看看 NOT( ) 方法。

假設有這樣的一個查詢語句:

SELECT * FROM SOME_TABLE WHERE NOT(1 = 1)

資料庫首先會計算 1=1,這個顯然是 true。

接着,資料庫會應用 NOT() 條件,是以 WHERE 傳回 false。

是以,上面的查詢不會傳回任何資料。

但如果把語句改成這樣:

SELECT * FROM SOME_TABLE WHERE NOT(1 = 0)

資料庫首先會計算 1=0,這個肯定是 false。

接着,資料庫應用 NOT() 條件,這樣就得到相反的結果,變成了 true。

是以,這個語句會傳回資料。

但如果把語句再改成下面這樣呢?

SELECT * FROM SOME_TABLE WHERE NOT(1 = NULL)

資料庫首先計算 1=NULL,它不知道 1 是否等于 NULL,因為它不知道 NULL 的值是什麼。

是以,這個計算不會傳回 true,也不會傳回 false,它會傳回一個 NULL。

接下來,NOT() 會繼續解析上一個計算傳回的結果。

當 NOT() 遇到 NULL,它會生成另一個 NULL。未知的相反面是另一個未知。

是以,對于這兩個查詢:

1

2

都不會傳回資料,盡管它們是完全相反的。

NULL 和 NOT IN

如果我有這樣的一個查詢語句:

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

很顯然,WHERE 傳回 true,這個語句将傳回資料,因為 1 在括号清單裡是存在的。

但如果這麼寫:

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

很顯然,WHERE 傳回 false,這個查詢不會傳回資料,因為 1 在括号清單裡存在,但我們說的是“NOT IN”。

但如果我們把語句改成這樣呢?

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

這裡的 WHERE 不會傳回資料,因為它的結果不是 true。數字 5 在括号清單裡可能不存在,也可能存在,因為當中有一個 NULL 值(資料庫不知道 NULL 的值是什麼)。

這個 WHERE 會傳回 NULL,是以整個查詢不會傳回任何資料。

希望大家現在都清楚該怎麼在 SQL 語句中處理 NULL 值了。

原文連結:

https://blog.csdn.net/qq_39390545/article/details/105859502

版權聲明:本文為CSDN部落客「_陳哈哈」的原創文章,遵循CC 4.0 BY-SA版權協定,轉載請附上原文出處連結及本聲明。