1 decode(条件,值1,翻译值1,值2,翻译值2,...值n,翻译值n,缺省值)
2 【功能】根据条件返回相应值
3 【参数】c1, c2, ...,cn,字符型/数值型/日期型,必须类型相同或null
4 注:值1……n 不能为条件表达式,这种情况只能用case when then end解决
5
6 ·含义解释:
7   decode(条件,值1,翻译值1,值2,翻译值2,...值n,翻译值n,缺省值)
8   该函数的含义如下:
9   IF 条件=值1 THEN
10   RETURN(翻译值1)
11   ELSIF 条件=值2 THEN
12   RETURN(翻译值2)
13   ......
14   ELSIF 条件=值n THEN
15   RETURN(翻译值n)
16   ELSE
17   RETURN(缺省值)
18   END IF
19
20 或:
21   when case 条件=值1 THEN
22   RETURN(翻译值1)
23   ElseCase 条件=值2 THEN
24   RETURN(翻译值2)
25   ......
26   ElseCase 条件=值n THEN
27   RETURN(翻译值n)
28   ELSE
29   RETURN(缺省值)
30   END
31
32
33 【示例】
34   ·使用方法:
35   1、比较大小
36   select decode(sign(变量1-变量2),-1,变量1,变量2) from dual; --取较小值
37   sign()函数根据某个值是0、正数还是负数,分别返回0、1、-1
38   例如:
39   变量1=10,变量2=20
40   则sign(变量1-变量2)返回-1,decode解码结果为“变量1”,达到了取较小值的目的。
41
42   2、表、视图结构转化
43   现有一个商品销售表sale,表结构为:
44   month    char(6)      --月份
45   sell    number(10,2)   --月销售金额  
46   现有数据为:
47   200001  1000
48   200002  1100
49   200003  1200
50   200004  1300
51   200005  1400
52   200006  1500
53   200007  1600
54   200101  1100
55   200202  1200
56   200301  1300
57
58   想要转化为以下结构的数据:
59   year   char(4)      --年份
60   month1  number(10,2)   --1月销售金额
61   month2  number(10,2)   --2月销售金额
62   month3  number(10,2)   --3月销售金额
63   month4  number(10,2)   --4月销售金额
64   month5  number(10,2)   --5月销售金额
65   month6  number(10,2)   --6月销售金额
66   month7  number(10,2)   --7月销售金额
67   month8  number(10,2)   --8月销售金额
68   month9  number(10,2)   --9月销售金额
69   month10  number(10,2)   --10月销售金额
70   month11  number(10,2)   --11月销售金额
71   month12  number(10,2)   --12月销售金额
72
73   结构转化的SQL语句为:
74
75   create or replace view
76   v_sale(year,month1,month2,month3,month4,month5,month6,
77   month7,month8,month9,month10,month11,month12)
78   as
79   select
80   substrb(month,1,4),
81   sum(decode(substrb(month,5,2),'01',sell,0)),
82   sum(decode(substrb(month,5,2),'02',sell,0)),
83   sum(decode(substrb(month,5,2),'03',sell,0)),
84   sum(decode(substrb(month,5,2),'04',sell,0)),
85   sum(decode(substrb(month,5,2),'05',sell,0)),
86   sum(decode(substrb(month,5,2),'06',sell,0)),
87   sum(decode(substrb(month,5,2),'07',sell,0)),
88   sum(decode(substrb(month,5,2),'08',sell,0)),
89   sum(decode(substrb(month,5,2),'09',sell,0)),
90   sum(decode(substrb(month,5,2),'10',sell,0)),
91   sum(decode(substrb(month,5,2),'11',sell,0)),
92   sum(decode(substrb(month,5,2),'12',sell,0))
93   from sale
94   group by substrb(month,1,4);
95

根据条件返回相应值 decode(条件,值1,翻译值1,值2,翻译值2,...值n,翻译值n,缺省值)的更多相关文章

  1. decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值)

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

  2. oracle函数 decode(条件,值1,翻译值1,值2,翻译值2,...值n,翻译值n,缺省值)

    [功能]根据条件返回相应值 [参数]c1, c2, ...,cn,字符型/数值型/日期型,必须类型相同或null 注:值1……n 不能为条件表达式,这种情况只能用case when then end解 ...

  3. [datatable]关于在DataTable中执行DataTable.Select("条件")返回DataTable的解决方法

    -- :09关于在DataTable中执行DataTable.Select("条件")返回DataTable的解决方法 在实际编程工程中,常常遇到这样的情况:DataTable并不 ...

  4. 在DataTable中执行DataTable.Select("条件")返回DataTable;

    转:http://blog.csdn.net/hcf_force/article/details/7779062 1.在DataTable中执行DataTable.Select("条件&qu ...

  5. linq 根据指定条件返回集合中不重复的元素

    原理:先查询出数据,根据指定值分组,然后取第一条映射 1.第一种方法 string sql = string.Format("select*from PoliceLogistcs); db. ...

  6. EXCEL应用:高级筛选里的条件或和与的条件怎么写 例:不包含,包含等

    ============================================================= a列包含b列,在c列中显示b列信息, =INDEX(B:B,MIN(IF(I ...

  7. pandas学习(常用数学统计方法总结、读取或保存数据、缺省值和异常值处理)

    pandas学习(常用数学统计方法总结.读取或保存数据.缺省值和异常值处理) 目录 常用数学统计方法总结 读取或保存数据 缺省值和异常值处理 常用数学统计方法总结 count 计算非NA值的数量 de ...

  8. if语句 条件测试 shell编程之条件语句

    shell 编程之条件语句一.条件测试  ① test命令 测试  ② 文件测试  ③ 整数值比较  ④ 字符串比较  ⑤ 逻辑测试二.if语句的结构  单分支结构  双分支结构  多分支结构三.ca ...

  9. C++:利用如下公式,编写函数计算∏的值,直到最后一项的绝对值小于e,主程序接收从键盘输入的e,输出∏的值(保留5位小数)。 ∏/4 = 1-1/3+1/5-1/7...

    利用如下公式,编写函数计算∏的值,直到最后一项的绝对值小于e,主程序接收从键盘输入的e,输出∏的值(保留5位小数). ∏/4 = 1-1/3+1/5-1/7... #include <iostr ...

随机推荐

  1. 一次完整的 HTTP 请求过程

    一次完整的HTTP请求过程从TCP三次握手建立连接成功后开始,客户端按照指定的格式开始向服务端发送HTTP请求,服务端接收请求后,解析HTTP请求,处理完业务逻辑,最后返回一个HTTP的响应给客户端, ...

  2. MUI 样式按钮的禁用

    1)如果是button,input等标签,可以     .attr("disabled",true)或者.attr("disabled","disab ...

  3. 所有HTTP请求参数及报文查看SERVLET【原】

    HttpRequestServlet.java 说明: 用于接受所有http形式的请求,并把接受到的request中param及getInputStream全打印出来. package king.se ...

  4. 直接用<img> 的src属性显示base64转码后的字符串成图片【原】

    直接用<img> 的src属性显示base64转码后的字符串成图片 <img src="data:image/gif;base64,base64转码后的字符串" ...

  5. CodeForces - 516B Drazil and Tiles(bfs)

    https://vjudge.net/problem/CodeForces-516B 题意 在一个n*m图中放1*2或者2*1的长方形,问是否存在唯一的方法填满图中的‘.’ 分析 如果要有唯一的方案, ...

  6. SQL语句(一)SQL和数据库数据表的创建

    SQL的组成 (1) 数据定义语言DDL(Data Definition Language) 用于数据库和数据表的创建.修改和删除等操作 CREATE (create) 创建数据库.数据表 ALTER ...

  7. SLT 优先队列 哈弗曼树最小带权路径

    与普通的队列不同,普通的队列是先进先出的,而优先队列出队的顺序不是先进先出,而是大(或者小)元素先出队,需要#include <queue> 成员函数 成员函数 作用 empty() 判断 ...

  8. IntelliJ IDEA AndroidStudio SVN无法使用

    1.Cann't Run Program "SVN" 把勾都去掉,结果没有任何反应.2.重新安装TotoriseSVN,设置Svn.exe路径,主要不要勾选Enable Inter ...

  9. fatal error C1083: 无法打开包括文件: “SDKDDKVer.h”: No such file or directory(转)

    fatal error C1083: 无法打开包括文件: “SDKDDKVer.h”: No such file or directory 解决办法:(Vs2013中) 项目--右键--属性--配置属 ...

  10. android contentprovider内容提供者

    contentprovider内容提供者:让其他app可以访问私有数据库(文件) 1.AndroidManifest.xml 配置provider <?xml version="1.0 ...