我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Oracle nvl、nvl2、nullif、decode、case函数详解

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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函数,后患无穷!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Oracle nvl、nvl2、nullif、decode、case函数详解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Oracle中decode函数详解

Oracle中的decode函数是一个条件表达式函数,用于根据给定的条件对一个或多个表达式进行比较,并返回与匹配条件相对应的结果表达式。语法:DECODE(expr, search1, result1, search2, result2,
2023-09-09

Oracle NVL函数详解及用法示例

Oracle NVL函数详解及用法示例在Oracle数据库中,NVL函数是一种非常常用的函数,其作用是用于判断一个值是否为null,若为null则返回另一个指定的值。本文将详细介绍NVL函数的语法、用法及提供一些示例代码以帮助读者更好地理
Oracle NVL函数详解及用法示例
2024-03-09

Oracle DECODE函数详解及用法示例

Oracle中的DECODE函数是一种条件表达式,常用于在查询语句中根据不同的条件返回不同的结果。本文将详细介绍DECODE函数的语法、用法和示例代码。一、DECODE函数语法DECODE(expr, search1, result1 [
Oracle DECODE函数详解及用法示例
2024-03-08

Oracle DECODE函数实例详解与应用场景

Oracle数据库是一种流行的关系型数据库管理系统,它提供了丰富的函数和工具来处理复杂的数据操作。其中,DECODE函数是一个非常常用的函数之一,可以根据指定的条件对数据进行转换和处理。本文将详细介绍Oracle的DECODE函数,包括语法
Oracle DECODE函数实例详解与应用场景
2024-03-07

编程热搜

目录