13.Oracle中nvl()与nvl2()函数详解

Oracle中nvl()与nvl2()函数详解:

函数nvl(expression1,expression2)根据参数1是否为null返回参数1或参数2的值;

函数nvl2(expression1,expression2,expression3)根据参数1是否为null返回参数2或参数3的值

1.nvl:根据参数1是否为null返回参数1或参数2的值

【函数格式】:nvl(expression1,expression2)

若expression1值为null,则该函数返回expression2;

若expression1值不为null,则该函数返回expression1;

若expression1、expression2的值均为null,则该函数返回null。

【特别说明】:参数expression1和expression2可以是字符型、数字型或日期型,但参数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为数值型:

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; --返回:12345

expression1为数值型:

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:根据参数1是否为null返回参数2或参数3的值

【函数格式】:nvl2(expression1,expression2,expression3)

若expression1值不为null,则该函数返回expression2值;

若expression1值为null,则该函数返回expression3值;

若expression1、expression2、expression3值均为null,则该函数返回null。

【特别说明】:

expression1的类型不需要与expression2和expression3的类型保持一致;

expression2与expression3的类型尽量保持一致,若不一致,当expression1为null时,则expression3会自动转换为expression2的类型,若两个数据类型之间无法转换,则会报错。

【样例展示一】: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; --返回:1234

expression2和expression3均为数值型:

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; --返回:-12345

expression2和expression3数据类型不一致:

注意:此时expression1有值,因此该函数直接返回expression2的值,即使expression3的类型无法转换为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; --返回:1234

expression2和expression3均为数值型:

select nvl2(null,12345,54321) from dual; --返回:54321

select nvl2('',123.45,543.21) from dual; --返回:543.21

相关推荐
怪兽201411 分钟前
Redis常见性能问题和解决方案
java·数据库·redis·面试
计算机学长felix31 分钟前
基于SpringBoot的“中学信息技术课程教学网站”的设计与实现(源码+数据库+文档+PPT)_2025-10-17
数据库·spring boot·后端
长安城没有风1 小时前
从入门到精通【Redis】Redis 典型应⽤ --- 缓存 (cache)
数据库·redis·后端·缓存
学无止境w1 小时前
Redis在电商中的深度应用:商品缓存、秒杀锁、排行榜的实现与避坑指南
数据库·redis·缓存
象象翔1 小时前
Redis实战篇---添加缓存(店铺类型添加缓存需求)
数据库·redis·缓存
放弃幻想_1 小时前
S4和ECC或者不通CLIENT,不通HANA服务器互相取数
服务器·数据库·sap·abap·abap sap
gx23481 小时前
MySQL-2--数据库的查询
数据库
zone_z2 小时前
Oracle 表空间检查与监控配置详解
数据库·oracle
冉冰学姐3 小时前
SSM装修服务网站5ff59(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·ssm 框架·装修服务网站
库库8393 小时前
Redis分布式锁、Redisson及Redis红锁知识点总结
数据库·redis·分布式