zoukankan      html  css  js  c++  java
  • [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测试

    1. SELECT
    2. SUM( DECODE( ENAME, 'SMITH', SAL, 0 ) ) SMITH,
    3. SUM( DECODE( ENAME, 'ALLEN', SAL, 0 ) ) ALLEN,
    4. SUM( DECODE( ENAME, 'WARD', SAL, 0 ) ) WARD,
    5. SUM( DECODE( ENAME, 'JONES', SAL, 0 ) ) JONES,
    6. SUM( DECODE( ENAME, 'MARTIN', SAL, 0 ) ) MARTIN
    7. FROM
    8. 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测试

    1. SELECT
    2. ENAME,
    3. SAL,
    4. DECODE( INSTR( ENAME, 'S' ), 0, '不含有s', '含有s' ) AS INFO
    5. FROM
    6. 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

  • 相关阅读:
    HeadFirst学习笔记-1. 设计模式入门(转载)
    【译】StackExchange.Redis 中文文档目录(转载)
    Redis基础篇(一)数据类型与数据结构(转载)
    Redis基础(二)数据库(转载)
    Redis基础篇(八)数据分片(转载)
    Redis基础篇(七)哨兵机制(转载)
    Redis基础篇(六)数据同步:主从复制(转载)
    Python特点
    Python发展历史
    Python基础
  • 原文地址:https://www.cnblogs.com/tingxin/p/12782561.html
Copyright © 2011-2022 走看看