Oracle之nvl

来源:互联网 发布:参苓白术丸 知柏地黄丸 编辑:程序博客网 时间:2024/06/06 11:02

1.nvl函数

NVL函数是一个空值转换函数
NVL(表达式1,表达式2)
如果表达式1为空值,NVL返回值为表达式2的值,否则返回表达式1的值。该函数的目的是把一个空值(null)转换成一个实际的值。其表达式的值可以是数字型、字符型和日期型。但是表达式1和表达式2的数据类型必须为同一个类型


例子:

对数字型:NVL(comm,0);
对字符型 NVL( TO_CHAR(comm), 'No Commission')
对日期型 NVL(hiredate,' 31-DEC-99')

查询某个员工年薪,如果为空则用0代替

select (sal+nvl(comm,o))*12 from emp where emp.pno=:pno;

这里,comm是未定义的变量,代指数字类型。 nvl返回为0.


2.nvl函数扩展

二 NVL2(表达式1,表达式2,表达式3)
如果表达式1为空,返回值为表达式3的值。如果表达式1不为空,返回值为表达式2的值。
例如 NVL2(comm,'sal+comm',sal)
NVL2函数测试comm
如果comm为空,就返回sal 的值。如果 comm 不为空(null),就返回表达式 sal+comm的值。


3.innvl函数

lnnvl用于某个语句的where子句中的条件,如果条件为真就返回真,否则为假。
其含义可理解为LNNVL == IS NULL OR IS NOT TRUE

它的优势在于处理简单条件判断无法实现的null条件,用举例说明

SQL> select * from plch_employees;

 EMPLOYEE_ID LAST_NAME           SALARY              COMMISSION_PCT
--------------------------------------- -------------------------------------------------------------------------------- ---------- --------------
  300       O'Keefe               1000000 
  100     Picasso                1000000             0.3
  200    Mondrian               1000000                 0.15
 

如果要查询commision)不大于20%, 或者为NULL的员工的姓名,则可以用下面

SQL> SELECT last_name FROM plch_employees e WHERE LNNVL (e.commission_pct > 0.2);
 

0 0
原创粉丝点击