你真的理解T-sql中的NULL嗎?

張博208發表於2017-02-17

NULL不表示什麼?
NULL不表示空字串,不表示0。

NULL表示什麼?
NULL表示不知道是什麼,就是說NULL的原意是不知道是什麼,表示可能什麼都是。

NULL與?做比較

PRINT (Case When NULL ='Value' Then 'true' else 'false' end)
PRINT (Case When NULL!='Value' Then 'true' else 'false' end)
PRINT (Case When NULL!=NULL Then 'true' else 'false' end)
PRINT (Case When NULL=NULL Then 'true' else 'false' end)

 

大家猜一下上面的4行表示式會返回什麼?,答案在下面


false
false
false
false


為什麼會有這樣的結果呢?
答案在MSDN上:
A value of NULL indicates that the value is unknown. A value of NULL is different from an empty or zero value. No two null values are equal. Comparisons between two null values, or between a NULL and any other value, return unknown because the value of each NULL is unknown.
既然如此,那我們應該怎樣與NULL值做比較呢,答案是用ISNULL函式,T-sql中ISNULL函式有兩個引數,第一個引數是要檢查是否為NULL的表示式,第二個引數是如果要檢查表示式為NULL時函式的返回值。

NULL與其他數值做運算

PRINT NULL
PRINT 1 + NULL;
PRINT 'yukaizhao' + NULL;
DECLARE @d datetime;
SET @d = GETDATE();
PRINT @d + NULL;

 

大家猜一下上面的語句會PRINT出來什麼?
答案是什麼都沒有,所有運算都和PRINT NULL是相同結果,結果還是NULL

NULL值與索引
如果一個列中有NULL值,那麼不可以在這個列上建唯一索引,可以建立非唯一索引;但是如果一個欄位有很多行有NULL值,那麼在這個欄位上建索引效果不佳。所以建議不在在一個頻繁出現NULL值的欄位上建索引(有待證實)

NULL與排序
NULL參與排序時總是作為最小值存在,即ORDER BY COL ASC時COL為NULL的行在最前面,反之在最後面。

附註:t-sql中三個關於NULL的函式:
ISNULL(check_expression, replacement_value)

check_expression 與 replacement_value 資料型別必須一致 
如果 check_expression 為 NULL,則返回 replacement_value 
如果 check_expression 不為 NULL,則返回 check_expression
 

NULLIF 用於檢查兩個表示式,語法:
NULLIF(expression, expression)

如果兩個 expression 相等,則返回 NULL,該 NULL 為第一個 expression 的資料型別 
如果兩個 expression 不相等,則返回第一個 expression

COALESCE()函式可以接受一系列的值,如果列表中所有項都為空(null),那麼只使用一個值。然後,它將返回第一個非空值。這一技巧描述了創造性使用SQL Server 中COALESCE()函式的兩種方法。

具體用法請參考:http://www.builder.com.cn/2007/0518/401640.shtml

相關文章