DECODE函数是ORACLE PL/SQL是功能强大的函数之一,目前还只有ORACLE公司的SQL提供了此函数,其他数据库厂商的SQL实现还没有此功能。DECODE有什么用途 呢? 先构造一个例子,假设我们想给智星职员加工资,其标准是:工资在8000元以下的将加20%;工资在8000元以上的加15%,通常的做法是,先选出记录 中的工资字段值? select salary into var-salary from employee,然后对变量var-salary用if-then-else或choose case之类的流控制语句进行判断。 如果用DECODE函数,那么我们就可以把这些流控制语句省略,通过SQL语句就可以直接完成。如下:select decode(sign(salary - 8000),1,salary*1.15,-1,salary*1.2,salary from employee 是不是很简洁? DECODE的语法:DECODE(value,if1,then1,if2,then2,if3,then3,...,else),表示如果value 等于if1时,DECODE函数的结果返回then1,...,如果不等于任何一个if值,则返回else。初看一下,DECODE 只能做等于测试,但刚才也看到了,我们通过一些函数或计算替代value,是可以使DECODE函数具备大于、小于或等于功能。

  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)),

Oracle中Decode()函数使用技巧相关推荐

  1. oracle 的wecate函数,1.Oracle中decode()函数用法

    1.Oracle中decode函数用法 含义解释: decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值) 该函数的含义如下: IF 条件=值1 THEN RETURN(翻 ...

  2. oracle+decode函数用法,oracle中decode函数用法

    oracle中decode函数用法以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! DECODE函数相当于一条件语句(IF ...

  3. oracle 中decode函数

    Oracle 中 decode 函数用法 含义解释: decode(条件,值1,返回值1,值2,返回值2,-值n,返回值n,缺省值) 该函数的含义如下: IF 条件=值1 THEN RETURN(翻译 ...

  4. linux decode函数,Oracle 中 decode 函数用法

    Decode函数与一系列嵌套的 IF-THEN-ELSE语句相似.base_exp与compare1,compare2等等依次进行比较.如果base_exp和 第i 个compare项匹配,就返回第i ...

  5. Oracle 中 decode 函数用法

    转载自:http://www.cnblogs.com/vinsonLu/p/3512526.html 含义解释: decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值) 该 ...

  6. oracle decode别名,Oracle中decode函数用法 VelHong

    DECODE函数与一系列嵌套的 IF-THEN-ELSE语句相似.base_exp与compare1,compare2等等依次进行比较.如果base_exp和 第i 个compare项匹配,就返回第i ...

  7. Oracle中decode函数用法解析以及常用场景

    1.decode函数的两种形式 第一种形式 含义解释: decode(条件,值1,返回值1,值2,返回值2,-值n,返回值n,缺省值) 该函数的含义如下: IF 条件=值1 THENRETURN(翻译 ...

  8. oracle中decode函数的使用

    一.DECODE函数相当于if条件语句,它将输入的值与函数中的参数列比较,根据输入值返回一个对应值 1.语法:decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值)   2 ...

  9. oracle decode嵌套,Oracle 中 Decode函数用法 | YuXi

    含义解释: decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值) 该函数的含义如下: IF 条件=值1 THEN RETURN(翻译值1) ELSIF 条件=值2 THE ...

最新文章

  1. 算法(掘金上经典的文档)
  2. android应用课程设计报告,基于Android的多媒体播放器课程设计报告.doc
  3. 程序员建议(忘记从哪里转的了,反正是csdn上的一个兄弟)
  4. hive的新分区和旧分区的概念问题
  5. [转]如何写好学术论文
  6. [Aaronyang] 写给自己的WPF4.5 笔记10[层次数据需求处理,TreeView绿色文章1/4]
  7. Could not create ServerSocket on address 0.0.0.0/0.0.0.0:9083
  8. 官宣,C罗回归曼联,签约两年,豪华阵容曝光
  9. VS2010闪退的问题
  10. 前端等值线分析DEMO(更新地址)
  11. 测试电梯的测试用例_测试面试题之如何测试电梯
  12. 论参加数学建模比赛的正确姿势
  13. 阿里云——云数据库RDS
  14. linux终端分屏工具tumx
  15. 【编程学习】浅谈哈希表及用C语言构建哈希表!
  16. 数据结构之——关键路径
  17. Windows7 下node下载及安装
  18. Qt编写地图综合应用59-经纬度坐标纠偏
  19. 研发人员绩效考核工作失败的几方面表现
  20. 「 Java基础-Lambda 」试试Lambda表达式?通俗易懂得嘞

热门文章

  1. C++bidirectional dijkstra双向最短路径算法(附完整源码)
  2. C语言实现词典编排算法(附完整源码)
  3. C语言实现队列ADT(Queue ADT)接口COMP2521(附完整源码)
  4. C++实现计数排序(附完整源码)
  5. Linux执行yum不显示时间图形,Linux停的yum命令详解(朝花夕拾)
  6. mysql索引 聚集索引_Mysql 索引实现原理. 聚集索引, 非聚集索引
  7. vba二维数组初始化_将工作表数据写入VBA数组
  8. python关键字列表的表达式,python 列表推导和生成器表达式的使用
  9. tensorflow中tf.get_variable()函数详解
  10. 28 Java类的加载机制、什么是类的加载、类的生命周期、加载:查找并加载类的二进制数据、连接、初始化、类加载器、双亲委派模型、自定义类加载器