加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

【聚焦oracle】ORACLE NVL 和 NVL2 函数的使用

发布时间:2020-12-12 15:08:13 所属栏目:百科 来源:网络整理
导读:NVL函数是一个空值转换函数,在SQL查询中主要用来处理null值。在不支持 null 值或 null 值无关紧要的情况下,可以使用 NVL( ) 来移去计算或操作中的 null 值。 Oracle在NVL函数的功能上扩展,提供了NVL2函数,使得不论目标值是否为null都能返回自定义的值。

NVL函数是一个空值转换函数,在SQL查询中主要用来处理null值。在不支持 null 值或 null 值无关紧要的情况下,可以使用 NVL( ) 来移去计算或操作中的 null 值。

Oracle在NVL函数的功能上扩展,提供了NVL2函数,使得不论目标值是否为null都能返回自定义的值。

工具/原料

  • ORACLE 11g R2 
  • PL/SQL Developer
方法/步骤
  1. 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;

    2.NVL2 ( )
  2. 语法: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;

  3. 如果两个指定的表达式相等,则返回空值

  4. 语法NULLIF(expression1,expression2) 参数expression1,expression2 常量、列名、函数、子查询或算术运算符、按位运算符以及字符串运算符的任意组合。 返回类型与第一个expression1相同。

    输出结果: 如果两个表达式不相等,NULLIF 返回第一个expression1的值。 如果两个表达式相等,NULLIF 返回空值NULL。 示例:

    1、两个表达式 相等,返回null

    [sql] view plain copy
    1. selectnullif(2+1,3)fromdual;
    2. nullif('abc','abc')fromdual;

    2、表达式不相等,返回第一个表达式值。

    copy nullif(1,2)fromdual;


3、null不可以作为第一个表达式,可以为第二个表达式

copy nullif(null,153); font-weight:bold; background-color:inherit">fromdual;


copy null)fromdual;


【聚焦软件开发 大鹏_James】

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读