在 SQL 語句中處理 NULL 值的方法

2022-09-21 00:42:10 字數 2588 閱讀 4242

在日常使用資料庫時,你在意過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 值和字串的處理方式是不一樣的:

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 一般會有三種結果:

你可能會想:「既然這樣,那我為什麼要去關心是 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。未知的相反面是另乙個未知。

所以,對於這兩個查詢:

select * from some_table where not(1 = null)

select * from some_table where 1 = null

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

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

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 值了。

SQL語句中null的應用。

首先推薦一下深入詳解sql中的null 這篇文章寫得比較全面了。這裡我說一下我遇到的問題。在設計乙個儲存過程時,我們經常把乙個變數查詢出來之後,放入乙個變數中。標準做法是,先select 資料賦值給變數。然後再判斷變數是否為空。如果事情到這裡,沒有問題了。當時為了偷懶直接使用了一些函式來處理null...

sql語句中的時間處理

我們在用sql語句處理資料庫資料時難免會遇到insert或者update一條資料,資料中的某個欄位是時間格式,那我們怎麼把引數的形式在sql語句中設定成時間格式呢,這裡記錄一下。update t bill contract bill set property fee 480.0,rent fee 6...

當sql語句中 遇到null發生的故事

今天測試過程發現個問題,sql語句中 不起作用,原sql語句如下 執行結果是0列 select from company member rel where companyid 111552 and active n 資料庫中,表company member rel部分資料如下 如果companyid...