oracle null值處理

來源:互聯網
上載者:User

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]...

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.