NVL和COALESCE的区别

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语句,效率更高,建议使用。

你可能感兴趣的:(工作,数据库)