欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

oracle nvl,nvl2,coalesce几个函数的区别

程序员文章站 2022-05-29 12:58:24
1.nvl(exp1,exp2)该函数是处理表达式中的空值: 假设表达式exp1是空值,则该函数返回表达式exp2的值, 假设表达式exp1没有是空值,则该函数返回表达式exp1的值。 2.nvl2(exp1,exp2,exp3)该函数决定exp1是空值和非空值时返回哪个表达式:假设exp1为空值, ......

1.nvl(exp1,exp2)
该函数是处理表达式中的空值:
假设表达式exp1是空值,则该函数返回表达式exp2的值,
假设表达式exp1没有是空值,则该函数返回表达式exp1的值。

2.nvl2(exp1,exp2,exp3)
该函数决定exp1是空值和非空值时返回哪个表达式:
假设exp1为空值,则返回exp3
假设exp1非空,返回exp2。

3.coalesce(exp1,exp2,.....)
该函数 返回 表达式中第一个非空值,假设都是空值,则返回空值,表达式最少是两个。


测试语句:

 1 -- nvl
 2 select nvl('1','2') from dual;
 3 
 4 select nvl(null,'2') from dual;
 5 
 6 -- nvl2
 7 select nvl2('1','2','3') from dual;
 8 
 9 select nvl2(null,'2','3') from dual;
10 
11 -- coalesce
12 select coalesce('是',null,'否') from dual;
13 
14 select coalesce(null,'是','否') from dual;
15 
16 select coalesce(null,null,'否') from dual;
17 
18 select coalesce(null,null,null) from dual;