[ORACLE]Oracle 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
2 使用decode判比较大小
Select decode(sign(var1-var2),1,var1,var2) from dual
Sign()函数根据某个值是0、正数、负数,分别返回0、1、-1;
Sql测试:
Select decode(sign(100-90),1,100,90) from dual
输出结果 :100
100-90=10>0则sign()返回1,decode()函数取值var1=100
Select decode(sign(100-90),-1,100,90) from dual
输出结果:90
100-90=10>0则sign()返回1,decode()函数取值var2=100
3.使用decode函数分段
工资大于10000为高薪,工资介于5000到10000为中等,工资小于5000位低薪
Sql测试:
SELECT ename,sal,
DECODE(SIGN(sal-10000),1,’高薪’,0,’高薪’,
-1,DECODE(SIGN(sal-5000),1’中等’,0,’中等’,
-1,’低薪’))) from ac01
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