Oracle的decode函数

标签: Oracle的decode函数
7人阅读 评论(0) 收藏 举报
分类:
decode的几种用法
1:使用decode判断字符串是否一样
DECODE(value,if1,then1,if2,then2,if3,then3,...,else)
含义为
IF 条件=值1 THEN
    RETURN(value 1)
ELSIF 条件=值2 THEN
    RETURN(value 2)
    ......
ELSIF 条件=值n THEN
    RETURN(value 3)
ELSE
    RETURN(default)
END IF


sql测试
select empno,decode(empno,7369,'smith',7499,'allen',7521,'ward',7566,'jones','unknow') as name from emp where rownum<=10
输出结果
7369 smith
7499 allen
7521 ward
7566 jones
7654 unknow
7698 unknow
7782 unknow
7788 unknow
7839 unknow
7844 unknow




2:使用decode比较大小
select decode(sign(var1-var2),-1,var 1,var2) from dual
sign()函数根据某个值是0、正数还是负数,分别返回0、1、-1
sql测试
select decode(sign(100-90),-1,100,90) from dual
输出结果
90
100-90=10>0 则会返回1,所以decode函数最终取值为90
反正
select decode(sign(100-90),1,100,90) from dual
输出结果
100
100-90=10>0返回1,判断结果为1,返回第一个变量100,最终输出结果为100




3:使用decode函数分段
工资大于5000为高薪,工资介于3000到5000为中等,工资小于3000为低薪
sql测试
SELECT 
    ename,sal,
    DECODE(SIGN(sal - 5000),
            1,
            'high sal',
            0,
            'high sal',
            - 1,
            DECODE(SIGN(sal - 3000),
                    1,
                    'mid sal',
                    0,
                    'mid sal',
                    - 1,
                    DECODE(SIGN(sal - 1000),
                            1,
                            'low sal',
                            0,
                            'low sal',
                            - 1,
                            'low sal')))
FROM
    emp
输出结果
SMITH   800    low sal
ALLEN 1600  low sal
WARD 1250  low sal
JONES 2975  low sal
MARTIN 1250  low sal
BLAKE   2850  low sal
CLARK 2450  low sal
SCOTT 3000  mid sal
KING  5000  high sal
TURNER 1500  low sal
ADAMS 1100  low sal
JAMES 950          low sal
FORD 3000  mid sal
MILLER 1300  low sal


4:利用decode实现表或者试图的行列转换
sql测试
SELECT 
       SUM(DECODE(ENAME,'SMITH',SAL,0))  SMITH,
       SUM(DECODE(ENAME,'ALLEN',SAL,0))  ALLEN,
       SUM(DECODE(ENAME,'WARD',SAL,0))   WARD,
       SUM(DECODE(ENAME,'JONES',SAL,0))  JONES,
       SUM(DECODE(ENAME,'MARTIN',SAL,0)) MARTIN FROM EMP
输出结果如下
SMITH  ALLEN  WARD   JONES  MARTIN
  800  1600    1250       2975       1250


5:使用decode函数来使用表达式来搜索字符串
decode (expression, search_1, result_1, search_2, result_2, ...., search_n, result_n, default)
decode函数比较表达式和搜索字,如果匹配,返回结果;如果不匹配,返回default值;如果未定义default值,则返回空值。
sql测试
SELECT 
    ENAME,
    SAL,
    DECODE(INSTR(ENAME, 'S'),
            0,
            '不含有s',
            '含有s') AS INFO
FROM
    EMP
输出结果
SMITH 800            含有s
ALLEN 1600    不含有s
WARD 1250    不含有s
JONES 2975     含有s
MARTIN 1250     不含有s
BLAKE 2850     不含有s
CLARK 2450     不含有s
SCOTT 3000    含有s
KING 5000    不含有s
TURNER 1500    不含有s
ADAMS 1100    含有s
JAMES 950             含有s
FORD 3000    不含有s
MILLER 1300    不含有s
查看评论

Oracle中Decode()函数使用技巧

  • 2009年05月27日 15:55
  • 9KB
  • 下载

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

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

oracle中 decode()函数简介

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

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:52
  • 3675

oracle中decode函数的使用

DECODE的语法:DECODE(value,if1,then1,if2,then2,if3,then3,...,else),表示如果value等于if1时,DECODE函数的结果返回then1,.....
  • xiabonihao
  • xiabonihao
  • 2016-11-15 09:22:14
  • 1372

Oracle—decode函数行转列

创建学生,课程,成绩三张表
  • Dream_angel_Z
  • Dream_angel_Z
  • 2014-11-10 20:29:36
  • 2466

[Oracle] decode 函数及其用法

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

Oracle中Decode()函数的有关用法

  • 2008年10月31日 14:28
  • 33KB
  • 下载

oracle sign函数解决大于小于的decode写法

select decode(sign(colA - colB) , -1 , colA + colB , colA) from table_namesign函数返回-1 , 0 , 1分别标识小于 ,...
  • gahaya
  • gahaya
  • 2012-11-17 09:31:23
  • 5469

Oracle 中 sign和decode 函数用法

1、 sign函数语法: sign(n); sign函数说明: 取数字n的符号,大于0返回1,小于0返回-1,等于0返回0(n可以是表达式,(n-200)) 例子: ...
  • u011410254
  • u011410254
  • 2015-11-09 17:27:47
  • 6684
    个人资料
    持之以恒
    等级:
    访问量: 1万+
    积分: 1230
    排名: 3万+
    图像处理加OpenCV博客推荐
    最新评论