mysql decode nvl2_Oracle nvl、nvl2、nullif、decode、case函数详解

1、NVL函数

nvl(expr1,expr2),如果expr1为空,则返回expr2;

2、NVL2函数

nvl2(expr1,expr2,expr3),如果expr1为空,则返回expr3,否则返回expr2;

3、NULLIF函数

nullif(expr1,expr2),如果expr1=expr2,返回空,否则返回expr1,要求两个表达式数据类型一致;

SQL> insert into t1 values(9);

说明1:NVL和NVL2函数在进行空值判断的时候,都会将函数内的表达式执行一次。

4、DECODE函数:

是oracle数据库独家提供的函数功能,不是sql标准,

相当于程序语言中的 if 1=1 then 1 else 1!=1的执行效果;

DECODE(value, if1, then1, if2,then2, if3,then3, . . . else )

5、CASE函数

case expr

when comparison_expr1 then return_expr1

when comparison_expr2 then return_expr2

when comparison_expr3 then return_expr3

......

when comparison_exprN then return_exprN

end

关于nvl、nvl2、decode函数执行性能比较

SQL> create table t1 (i int);--创建t1临时表

SQL> insert into t1 values(9);

SQL> insert into t1 values(9);--插入3行数据,数据值都是9

SQL> create or replace function sleep_now return number is

2  i number;

3  begin

4  i :=0;

5  while8

6  i<=1000000

7  loop

8  i :=i+1;

9  end loop;

10  return i;

11  end;

12  /                         --创建一个sleep_now函数,目的是为了加长sql执行的时间

SQL> set timing on;            --设置sqlplus命令执行时间

SQL> select  nvl(i,sleep_now()) from t1;

NVL(I,SLEEP_NOW())

------------------

9

9

9

Executed in 0.343 seconds  --判断t1表中的i字段是否为空,为空则执行sleep_now()函数;

sql执行时间是0.343秒;

SQL> select  nvl2(i,sleep_now(),1) from t1;

NVL2(I,SLEEP_NOW(),1)

---------------------

1000001

1000001

1000001

Executed in 0.343 seconds  --同样使用nvl2函数进行测试

--使用decode进行相同测试,执行时间是0.063秒

SQL> select decode(i,null,sleep_now(),1111) from t1;

DECODE(I,NULL,SLEEP_NOW(),1111

------------------------------

1111

1111

1111

Executed in 0.063 seconds

总结:错误的、不恰当的使用nvl函数,后患无穷!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值