oracle的nvl和nvl2是什么函数,两者区别是什么呢

oracle的nvl和nvl2是什么函数,两者区别是什么呢,第1张

oracle的NVL函数的功能室如果oracle第一个参数为空那么显示第二个参数的值,如果第一个参数的值不为空,则显示第一个参数本来的值。

NVL(E1, E2)的功能为:如果E1为NULL,则函数返回E2,否则返回E1本身。但此函数有一定局限,所以就有了NVL2函数。

NVL2函数的格式如下:NVL2(expr1,expr2, expr3)

含义是:如果该函数的第一个参数为空那么显示第二个参数的值,如果第一个参数的值不为空,则显示第三个参数的值。

NVL2函数:Oracle/PLSQL中的一个函数,NVL2(E1, E2, E3)的功能为:如果E1为NULL,则函数返回E3,若E1不为null,则返回E2。

扩展资料:

NVL函数的功能是实现空值的转换,根据第一个表达式的值是否为空值来返回响应的列名或表达式,主要用于对数据列上的空值进行处理,语法格式如:NVL( string1, replace_with)

如果第一个参数的值为空值,则返回第二个参数的值,否则返回第一个参数的值。如果两个参数的值都为空值,则返回空值。

第一个参数和第二个参数可以是任何类型的数据,但两个参数的数据类型必须相同(或能够由Oracle隐式转换为相同的类型)。

参考资料来源:百度百科--nvl函数

1.NVL ( )语法:nvl(expr1,expr2)

如果 expr1 是 null 值,则 nvl 函数返回 expr2 ,否则就返回 expr1 。

说明:参数 expr1、expr2 可以是任何数据类型,但应该保持相同。若两者数据类型不一致,则Oracle数据库会隐式的转换其中一个的数据类型使其保持和另一个一致,若无法转换则会返回错误。隐式转换的实施规则如下:

(1)若 expr1 是字符数据,则Oracle数据库在比较之前就会把 expr2 转换成 expr1 的数据类型并且返回 VARCHAR2 数据类型到 expr1 的字符集。

(2) 若 expr1 是数值型,则Oracle数据库决定哪个参数具有最高数值优先级,并把另一个参数的数据类型隐式转换成这种数据类型,并返回这种数据类型的数据。

实例:返回员工姓名和奖金,若该员工没有奖金则返回 Not Applicable

SELECT last_name, NVL(TO_CHAR(commission_pct), 'Not Applicable')"COMMISSION"

FROM employees

WHERE last_name LIKE 'B%'

ORDER BY last_name

ORACLE NVL 和 NVL2 函数的使用

2.NVL2 ( )

语法:nvl2(expr1,expr2,expr3)

如果 expr1 不是 null 值,则 nvl 函数返回 expr2 ,否则就返回 expr3 。参数可以返回任何数据类型的值,但是 expr2 和 expr3 不能是 LONG 型的数据类型。

说明:若 expr2 和 expr3 的数据类型不同:

(1)若 expr2 是字符数据,则Oracle数据库在比较之前就会把 expr3 转换成 expr2 的数据类型除非 expr3 是null。在 这种情况下,隐式数据转换是不必要的。Oracle数据库返回 VARCHAR2 数据类型到 expr2 的字符集。

(2) 若 expr2 是数值型,则Oracle数据库决定哪个参数具有最高数值优先级,并把另一个参数的数据类型隐式转换成这种数据类型,并返回这种数据类型的数据。

实例:返回员工收入,看员工收入(income)是否由工资(salary)加奖金(commission)组成,这取决于commission_pct列是否为null

SELECT last_name, salary, NVL2(commission_pct, salary + (salary * commission_pct), salary) income FROM employees

WHERE last_name like 'B%'

ORDER BY last_name

ORACLE NVL 和 NVL2 函数的使用

如果需要为查询出的为 null 的字段,设置一个默认值,就可以使用 NVL 函数。如果 expr1 为 null ,则 NVL 会返回 expr2。 如果 expr1 不为 null ,则 NVL 返回 expr1 。

参数 expr1 和 expr2 可以是任何 Oracle 数据类型。如果这两个参数的数据类型不同,那么 Oracle 隐式转换。如果不能转换,则会返回一个错误。

假设有一张表,包含一个 PASSWORD_CHANGE_DATE 字段,它是 Date 类型。我们希望查询出来的结果集中 PASSWORD_CHANGE_DATE 字段如果为 null,则显示为 ‘未改动’:

如果这样写,就会抛出错误。因为 NVL 的 expr1 是 Date 类型,而 expr2 却是字符型。

修改 SQL 语句,使用 to_char 对其进行类型转换:

运行结果:

NVL2 可以根据指定表达式 expr1 是否为空来决定实际的返回值。如果 expr1 不为 null,则 返回 expr2。 如果 expr1 为 null,则返回 expr3。 类似 Java 中的三元选择符。

参数 expr1 可以是任何数据类型。而参数 expr2 和 expr3 可以是除了 LONG 之外的其它数据类型。

还是之前的那张表。我们希望查询出来的结果集中 PASSWORD_CHANGE_DATE 字段如果为 null,则显示为 ‘未改动’;如果字段不为 null,则显示为 '已改动’。

运行结果:


欢迎分享,转载请注明来源:夏雨云

原文地址:https://www.xiayuyun.com/zonghe/23565.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-02-16
下一篇2023-02-16

发表评论

登录后才能评论

评论列表(0条)

    保存