当前位置:   article > 正文

NVL和COALESCE的区别_coalesce和nvl

coalesce和nvl

1、nvl

nvl 函数语法 nvl(默认值,表达式);如果 默认值为不为空返回默认值,默认值为空 返回 表达式值,如果两者都为空返回空,----处理参数个数有限,只能传两个参数。使用时需注意:默认值,表达式的值数据类型没有要求,可相同可不同。

如:nvl(a,b),若a为空,返回b,若a为非空返回a。

2、coalesce

coalesce 函数语法为 coalesce(表达式1,表达式2....表达式n);coalesce函数的返回结果是第一个非空表达式,如果全是空则,返回空。----处理参数个数没有限制。使用时需注意:对处理参数的数据类型有严格要求,所有表达式值是同一类型(转换同一类型亦可)。

3、滥用 NVL 可能导致额外的计算

NVL无论前面的参数是否为 NULL 均会计算所有参数
COALESCE如果遇到一个不为 NULL 的参数,则不计算后面的表达式

4、简单总结

  • nvl:支持两个参数。其本质是个函数。
  • coalesce:如果第一个参数为空就取第二个参数的值,第二个参数可以为常数也可以为表达式(字段,语句等)。以此类推,支持多个参数。更常用,其本质是个语句,更像个if语句,效率更高,建议使用。
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/繁依Fanyi0/article/detail/973655
推荐阅读
相关标签
  

闽ICP备14008679号