Oracle中nvl()和nvl2()函數(shù)實例詳解
Oracle中nvl()與nvl2()函數(shù)詳解:
- 函數(shù)nvl(expression1,expression2)根據(jù)參數(shù)1是否為null返回參數(shù)1或參數(shù)2的值;
- 函數(shù)nvl2(expression1,expression2,expression3)根據(jù)參數(shù)1是否為null返回參數(shù)2或參數(shù)3的值。
1.nvl:根據(jù)參數(shù)1是否為null返回參數(shù)1或參數(shù)2的值
【函數(shù)格式】:nvl(expression1,expression2)
【函數(shù)說明】:
- 若expression1值為null,則該函數(shù)返回expression2;
- 若expression1值不為null,則該函數(shù)返回expression1;
- 若expression1、expression2的值均為null,則該函數(shù)返回null。
【特別說明】:參數(shù)expression1和expression2可以是字符型、數(shù)字型或日期型,但參數(shù)expression1與expression2的類型必須一致。
【樣例展示一】:expression1值為null:
expression2為字符型:
select nvl(null,'ABCD') from dual; --返回:ABCD select nvl(null,'abcd') from dual; --返回:abcd select nvl(null,'12345') from dual; --返回:12345
expression2為數(shù)值型:
select nvl(null,12345) from dual; --返回:12345 select nvl(null,00000) from dual; --返回:0 select nvl(null,-12345) from dual; --返回:-12345 select nvl(null,123.45) from dual; --返回:123.45 select nvl(null,-123.45) from dual; --返回:-123.45
expression2為日期時間型:
select nvl(null,sysdate) from dual; --返回:2022/2/25 11:54:18
select nvl(null,to_date('2022/2/25 11:54:18','yyyy-mm-dd hh24:mi:ss')) from dual; --返回:2022/2/25 11:54:18
select nvl(null,to_date('2022/2/25','yyyy-mm-dd')) from dual; --返回:2022/2/25
select nvl(null,to_date('2022','yyyy')) from dual; --返回:2022/2/1【樣例展示二】:expression1值不為null:
expression1為字符型:
select nvl('ABCD','abcd') from dual; --返回:ABCD
select nvl('abcd','ABCD') from dual; --返回:abcd
select nvl('12345','54321') from dual; --返回:12345expression1為數(shù)值型:
select nvl(12345,null) from dual; --返回:12345 select nvl(00000,11111) from dual; --返回:0 select nvl(-12345,null) from dual; --返回:-12345 select nvl(123.45,-123.45) from dual; --返回:123.45 select nvl(-123.45,123.45) from dual; --返回:-123.45
expression1為日期時間型:
select nvl(sysdate,null) from dual; --返回:2022/2/25 12:18:23
select nvl(to_date('2022/2/25 12:18:23','yyyy-mm-dd hh24:mi:ss'),null) from dual; --返回:2022/2/25 12:18:23
select nvl(to_date('2022/2/25','yyyy-mm-dd'),null) from dual; --返回:2022/2/25
select nvl(to_date('2022','yyyy'),null) from dual; --返回:2022/2/1【樣例展示三】:expression1、expression2值均為null:
select nvl(null,null) from dual; --返回空值
select nvl('',null) from dual; --返回空值
select nvl(null,'') from dual; --返回空值
select nvl('','') from dual; --返回空值2.nvl2:根據(jù)參數(shù)1是否為null返回參數(shù)2或參數(shù)3的值
【函數(shù)格式】:nvl2(expression1,expression2,expression3)
【函數(shù)說明】:
- 若expression1值不為null,則該函數(shù)返回expression2值;
- 若expression1值為null,則該函數(shù)返回expression3值;
- 若expression1、expression2、expression3值均為null,則該函數(shù)返回null。
【特別說明】:
- expression1的類型不需要與expression2和expression3的類型保持一致;
- expression2與expression3的類型盡量保持一致,若不一致,當(dāng)expression1為null時,則expression3會自動轉(zhuǎn)換為expression2的類型,若兩個數(shù)據(jù)類型之間無法轉(zhuǎn)換,則會報錯。
【樣例展示一】:expression1值不為null:
expression2和expression3均為字符型:
select nvl2(0,'ABCD','abcd') from dual; --返回:ABCD
select nvl2('a','ABCD','1234') from dual; --返回:ABCD
select nvl2(sysdate,'1234','abcd') from dual; --返回:1234expression2和expression3均為數(shù)值型:
select nvl2(0,12345,54321) from dual; --返回:12345
select nvl2('a',123.45,543.21) from dual; --返回:123.45
select nvl2(sysdate,-12345,-54321) from dual; --返回:-12345expression2和expression3數(shù)據(jù)類型不一致:
注意:此時expression1有值,因此該函數(shù)直接返回expression2的值,即使expression3的類型無法轉(zhuǎn)換為expression2的類型也不會報錯。
select nvl2(0,'ABCD',54321) from dual; --返回:ABCD
select nvl2('a','abcd',543.21) from dual; --返回:abcd
select nvl2(sysdate,'12345',-54321) from dual; --返回:12345【樣例展示二】:expression1值為null:
expression2和expression3均為字符型:
select nvl2(null,'ABCD','abcd') from dual; --返回:abcd
select nvl2('','ABCD','1234') from dual; --返回:1234expression2和expression3均為數(shù)值型:
select nvl2(null,12345,54321) from dual; --返回:54321
select nvl2('',123.45,543.21) from dual; --返回:543.21expression2和expression3數(shù)據(jù)類型不一致:
注意:此時expression1值為null,因此該函數(shù)會返回expression3的值,若expression3的類型無法轉(zhuǎn)換為expression2的類型,則會報錯。
select nvl2(null,'ABCD',54321) from dual; --返回:54321
select nvl2('','abcd',543.21) from dual; --返回:543.21
select nvl2('',543.21,'abcd') from dual; --執(zhí)行報錯
select nvl2(null,'abcd',sysdate) from dual; --返回:25-2月 -22
select nvl2(null,sysdate,'abcd') from dual; --執(zhí)行報錯【樣例展示三】:expression1為null,且expression2或expression3值為null:
select nvl2(null,null,'123') from dual; --返回:123
select nvl2(null,'abc',null) from dual; --返回:空值
select nvl2(null,null,null) from dual; --返回:空值
select nvl2('','','') from dual; --返回:空值
總結(jié)
到此這篇關(guān)于Oracle中nvl()和nvl2()函數(shù)詳解的文章就介紹到這了,更多相關(guān)Oracle nvl()和nvl2()函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
window10 安裝Oracle19C 和SQL Developer 的圖文教程
這篇文章主要介紹了window10 安裝Oracle19C 和SQL Developer 教程(圖文詳解),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03
oracle與gbase8s遷移數(shù)據(jù)類型對照以及舉例說明
gbase8s是一個高性能的分布式關(guān)系型數(shù)據(jù)庫,下面這篇文章主要給大家介紹了關(guān)于oracle與gbase8s遷移數(shù)據(jù)類型對照以及舉例說明的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-12-12
oracle impdp network_link參數(shù)使用介紹
本文將介紹oracle impdp network_link參數(shù)使用方法,需要了解更多的朋友可以參考下2012-11-11
oracle正則表達(dá)式多項匹配時相似項有優(yōu)先級詳解
這篇文章主要給大家介紹了關(guān)于oracle正則表達(dá)式多項匹配時相似項有優(yōu)先級的相關(guān)資料,Oracle中使用正則表達(dá)式需先使用REGEXP_LIKE函數(shù)來匹配字符串,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-06-06
oracle導(dǎo)出sql語句的結(jié)果集和保存執(zhí)行的sql語句(深入分析)
本篇文章是對oracle導(dǎo)出sql語句的結(jié)果集與保存執(zhí)行的sql語句進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05

