oracle的nvl函數(shù)的使用介紹
Oracle的Nvl函數(shù)
nvl( ) 函數(shù)
從兩個表達式返回一個非null 值。
語法
NVL(eExpression1, eExpression2)
參數(shù)
eExpression1, eExpression2
如 果 eExpression1 的計算結(jié)果為 null 值,則 NVL( ) 返回 eExpression2。如果 eExpression1 的計算結(jié)果不是 null 值,則返回 eExpression1。eExpression1 和 eExpression2 可以是任意一種數(shù)據(jù)類型。如果 eExpression1 與 eExpression2 的結(jié)果皆為 null 值,則 NVL( ) 返回 .NULL.。
返回值類型
字符型、日期型、日期時間型、數(shù)值型、貨幣型、邏輯型或 null 值
說明
在不支持 null 值或 null 值無關緊要的情況下,可以使用 NVL( ) 來移去計算或操作中的 null 值。
select nvl(a.name,'空得') as name from student a joinschool b on a.ID=b.ID
注意:兩個參數(shù)得類型要匹配
問:什么是NULL?
答:在我們不知道具體有什么數(shù)據(jù)的時候,也即未知,可以用NULL,
我們稱它為空,ORACLE中,含有空值的表列長度為零。
ORACLE允許任何一種數(shù)據(jù)類型的字段為空,除了以下兩種情況:
1、主鍵字段(primary key),
2、定義時已經(jīng)加了NOT NULL限制條件的字段
說明:
1、等價于沒有任何值、是未知數(shù)。
2、NULL與0、空字符串、空格都不同。
3、對空值做加、減、乘、除等運算操作,結(jié)果仍為空。
4、NULL的處理使用NVL函數(shù)。
5、比較時使用關鍵字用“is null”和“is not null”。
6、空值不能被索引,所以查詢時有些符合條件的數(shù)據(jù)可能查不出來,
count(*)中,用nvl(列名,0)處理后再查。
7、排序時比其他數(shù)據(jù)都大(索引默認是降序排列,小→大),
所以NULL值總是排在最后。
相關文章
安裝Oracle完整客戶端后沒有訪問接口OraOLEDB.Oracle解決辦法
這篇文章主要給大家介紹了關于安裝Oracle完整客戶端后沒有訪問接口OraOLEDB.Oracle的解決辦法,文中通過代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考解決價值,需要的朋友可以參考下2024-01-01
給Oracle添加split和splitstr函數(shù)的方法
最近項目中有很多需要做批量操作的需求,客戶端把一組逗號分隔的ID字符串傳給數(shù)據(jù)庫,存儲過程就需要把它們分割,然后逐個處理2012-11-11
oracle數(shù)據(jù)庫優(yōu)化輔助SQL語句
這篇文章主要介紹了oracle數(shù)據(jù)庫優(yōu)化輔助SQL語句,需要的朋友可以參考下2015-10-10

