Oracle中decode()函数的使用技巧

原创 2007年09月18日 19:04:00

出处:http://markriver.itpub.net/post/768/13248

decode()函數使用技巧
·软件环境:
1、Windows NT4.0+ORACLE 8.0.4
2、ORACLE安装路径为:C:ORANT
·含义解释:
decode(条件,值1,翻译值1,值2,翻译值2,...值n,翻译值n,缺省值)

该函数的含义如下:
IF 条件=值1 THEN
    RETURN(翻译值1)
ELSIF 条件=值2 THEN
    RETURN(翻译值2)
    ......
ELSIF 条件=值n THEN
    RETURN(翻译值n)

ELSE
    RETURN(缺省值)
END IF
·        使用方法:
1、比较大小
select decode(sign(变量1-变量2),-1,变量1,变量2) from dual; --取较小值
sign()函数根据某个值是0、正数还是负数,分别返回0、1、-1

例如:
变量1=10,变量2=20
则sign(变量1-变量2)返回-1,decode解码结果为“变量1”,达到了取较小值的目的。


2、表、视图结构转化
现有一个商品销售表sale,表结构为:
month    char(6)      --月份
sell    number(10,2)   --月销售金额

现有数据为:
200001  1000
200002  1100
200003  1200
200004  1300
200005  1400
200006  1500
200007  1600
200101  1100
200202  1200
200301  1300

想要转化为以下结构的数据:
year   char(4)      --年份
month1  number(10,2)   --1月销售金额
month2  number(10,2)   --2月销售金额
month3  number(10,2)   --3月销售金额
month4  number(10,2)   --4月销售金额
month5  number(10,2)   --5月销售金额
month6  number(10,2)   --6月销售金额
month7  number(10,2)   --7月销售金额
month8  number(10,2)   --8月销售金额
month9  number(10,2)   --9月销售金额
month10  number(10,2)   --10月销售金额
month11  number(10,2)   --11月销售金额
month12  number(10,2)   --12月销售金额

结构转化的SQL语句为:
create or replace view
v_sale(year,month1,month2,month3,month4,month5,month6,month7,month8,month9,month10,month11,month12)
as
    select
    substrb(month,1,4),
    sum(decode(substrb(month,5,2),'01',sell,0)),
    sum(decode(substrb(month,5,2),'02',sell,0)),
    sum(decode(substrb(month,5,2),'03',sell,0)),
    sum(decode(substrb(month,5,2),'04',sell,0)),
    sum(decode(substrb(month,5,2),'05',sell,0)),
    sum(decode(substrb(month,5,2),'06',sell,0)),
    sum(decode(substrb(month,5,2),'07',sell,0)),
    sum(decode(substrb(month,5,2),'08',sell,0)),
    sum(decode(substrb(month,5,2),'09',sell,0)),
    sum(decode(substrb(month,5,2),'10',sell,0)),
    sum(decode(substrb(month,5,2),'11',sell,0)),
    sum(decode(substrb(month,5,2),'12',sell,0))
    from sale
    group by substrb(month,1,4);
  

[Oracle] decode 函数及其用法

DECODE()函数,它将输入数值与函数中的参数列表相比较,根据输入值返回一个对应值。函数的参数列表是由若干数值及其对应结果值组成的若干序偶形式。当然,如果未能与任何一个实参序偶匹配成功,则函数也有默...
  • oscar999
  • oscar999
  • 2014年01月17日 17:54
  • 27236

oracle最强大函数之一decode函数的使用

decode的几种用法 1:使用decode判断字符串是否一样 DECODE(value,if1,then1,if2,then2,if3,then3,...,else) 含义为 IF 条件=值...
  • weeknd
  • weeknd
  • 2017年05月04日 00:48
  • 3672

oracle中 decode()函数简介

今天看别人的SQL时看这里面还有decode()函数,以前从来没接触到,上网查了一下,还挺好用的一个函数,写下来希望对朋友们有帮助哈!...
  • young_kim1
  • young_kim1
  • 2015年07月14日 16:46
  • 1513

Oracle中decode函数用法含义

decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值) decode(字段或字段的运算,值1,值2,值3) SELECT DECODE (value, , ) FROM t...
  • u012456926
  • u012456926
  • 2014年10月16日 12:41
  • 3252

oracle数据库中decode函数与 mysql中的if函数和case函数

转自:http://www.cnblogs.com/chero/archive/2012/12/06/2804940.html oracle中有decode函数,如下:   select sum(...
  • qq_21144531
  • qq_21144531
  • 2015年08月25日 20:49
  • 1731

Oracle函数介绍:decode

1、Oracle函数介绍:decode   Sql代码  select sum(DECODE(C810000125,'是',1,0))/COUNT(1) 合格率 FROM t581  统计合格...
  • ystyaoshengting
  • ystyaoshengting
  • 2013年02月19日 10:40
  • 15039

hive的UDF实现类似于oracle的decode函数功能

客户提的要求,让实现
  • zhoudetiankong
  • zhoudetiankong
  • 2014年04月22日 10:13
  • 1680

Oracle中Decode()函数使用技巧

decode()函数是ORACLE PL/SQL是功能强大的函数之一,目前还只有ORACLE公司的SQL提供了此函数,其他数据库厂商的SQL实现还没有此功能。 DECODE函数是ORACLE P...
  • TZBiao
  • TZBiao
  • 2013年06月13日 22:39
  • 754

Oracle—decode函数行转列

创建学生,课程,成绩三张表
  • Dream_angel_Z
  • Dream_angel_Z
  • 2014年11月10日 20:29
  • 2024

Oracle中Decode()函数使用技巧

原文:http://blog.csdn.net/topsjava/article/details/1746284  DECODE函数是ORACLE PL/SQL是功能强大的函数之一,目前还只...
  • EmmaGood
  • EmmaGood
  • 2013年04月28日 10:03
  • 438
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Oracle中decode()函数的使用技巧
举报原因:
原因补充:

(最多只允许输入30个字)