1.NULL空值概念
資料庫裡有一個很重要的概念:空值即NULL。有時表中,更確切的說是某些欄位值,可能會出現空值, 這是因為這個資料不知道是什麼值或根本就不存在。
2.NULL空值判斷
空值不等同於字串中的空格,也不是數字類型的0 。因此,判斷某個欄位值是否為空白值時不能使用=,<>這些判斷符。必需有專用的短語:IS
NULL 來選出有空值欄位的記錄,同理,可用 IS NOT NULL 選出不包含空值的記錄。如:
SELECT
*FROM party WHERE leader IS NULL;
SELECT
*FROM party WHERE leader IS NOT NULL;
3.空值轉換
Oracle :
Nvl
NVL函數:
NVL函數是將NULL值的欄位轉換成預設欄位輸出。
NVL(expr1,expr2)
expr1,需要轉換的欄位名或者運算式。
expr2,null的替代值
下面是NUMBER, DATE, CHAR OR VARCHAR2的例子:
NVL(commission_pct,0)
NVL(hire_date,'01-JAN-97')
NVL(job_id,'No Job Yet')
Sql Server:
IsNull: 如果是Null,就返回指定的值,否則返回原值。
select userName,IsNULL(address,'無') from [user]...
------------------------------------------------------------------
NullIF 會在兩個值(或者運算式)相等的時候返回null,否則返回第一個參數。
select Sum(NullIf(price,100)) from ...
如果價格是100,就當null處理,sum()會忽略null值,所以...
----------------------------------------------------------------------
COALESCE 會返回第一個非空的值,參數是任意多個。
select Coalesce(homephone,officePhone,mobile) from....
只要有一個電話號碼被填寫了,就一定會返回一個值。
-----------------------------------------------------------------------
Access:
Nz
同Sql Server IsNull。只能在Access程式中使用,Jet ADO不支援
select userName,Nz(address,'無') from [user]...
IIF
select userName,IIF(address is null,'無',address) from [user]...
select userName,IIF(address is null,'沒寫','寫了') from [user]...