首页 > 其他 > 详细

Orcal nvl函数

时间:2019-11-20 12:54:59      阅读:88      评论:0      收藏:0      [点我收藏+]
NVL(E1, E2)的功能为:如果E1为NULL,则函数返回E2,否则返回E1本身。但此函数有一定局限,所以就有了NVL2函数。
拓展:NVL2函数:Oracle/PLSQL中的一个函数,Oracle在NVL函数的功能上扩展,提供了NVL2函数。NVL2(E1, E2, E3)的功能为:如果E1为NULL,则函数返回E3,若E1不为null,则返回E2。
NVL函数的功能是实现空值的转换,根据第一个表达式的值是否为空值来返回响应的列名或表达式,主要用于对数据列上的空值进行处理,语法格式如:NVL( string1, replace_with)
如果第一个参数的值为空值,则返回第二个参数的值,否则返回第一个参数的值。如果两个参数的值都为空值,则返回空值。第一个参数和第二个参数可以是任何类型的数据,但两个参数的数据类型必须相同(或能够由Oracle隐式转换为相同的类型)。
 
引申一下,此NVL的作用与SQLserver 中的 ISNULL( string1, replace_with) 一样。
另一个有关的有用方法
declare i integer
select nvl(sum(t.dwxhl),1) into i from tb_jhde t 
where zydm=-1
这样就可以把获得的合计值存储到变量
i中,如果查询的值为null就把它的值设置为默认的1
oracle中:
select nvl(rulescore,0) from zwjc_graderule 
where rulecode=FWTD;
如果记录中不存在rulecode =‘FWTD‘的数据.则查不出数据.
select nvl(rulescore,0) into rule_score from zwjc_graderule 
where rulecode=FWTD;
会报查不到数据的错
select nvl(sum(rulescore),0) from zwjc_graderule 
where rulecode=FWTD;
如果记录中不存在rulecode =‘FWTD‘的数据.还是可以得到一行列名为nvl(rulescore,0),值为0的数据.
select nvl(sum(rulescore),0) into rule_score from zwjc_graderule
where rulecode=FWTD; 
不会报错

Orcal nvl函数

原文:https://www.cnblogs.com/luzhanshi/p/11896055.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!