ORACLE NVL 和 NVL2 函数的使用

 时间:2026-02-16 02:06:13

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; 

ORACLE NVL 和 NVL2 函数的使用

2、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 函数的使用

  • Excel中使用Power Query实现数据的拆分与组合
  • 面试太紧张 不善表达怎么办?
  • excel中dollar函数使用方法
  • excel双击输入左侧单元格内容
  • 图示EXCEL表格vba系列67之BordersLineStyle网格
  • 热门搜索
    生命的意义手抄报 关于爱鸟护鸟的手抄报 交通安全手抄报题目 关于手抄报的图案 语文天地手抄报 与文明同行手抄报 爱祖国手抄报资料 动物手抄报内容 关于桥的手抄报图片 成语手抄报版面设计