oracle中空值null的判斷和轉換:NVL的用法


1.NULL空值概念

    數據庫里有一個很重要的概念:空值即NULL。有時表中,更確切的說是某些字段值,可能會出現空值, 這是因為這個數據不知道是什么值或根本就不存在。

2.NULL空值判斷

    空值不等同於字符串中的空格,也不是數字類型的0 。因此,判斷某個字段值是否為空值時不能使用=,<>,in,not in這些判斷符,如果非要用的話,可以用NVL(column_name,'sfd')<>'4'表示就可以了。必需有專用的短語: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]...

 

本文轉自:http://blog.sina.com.cn/s/blog_573a052b0100fu0d.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM