• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    oracle中decode函数的使用方法示例

    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

    Decode函数在实际开发中非常的有用

    结合Lpad函数,如何使主键的值自动加1并在前面补0

    select LPAD(decode(count(记录编号),0,1,max(to_number(记录编号)+1)),14,'0') 记录编号 from tetdmis

    eg:

    select decode(dir,1,0,1) from a1_interval

    dir 的值是1变为0,是0则变为1

    比如我要查询某班男生和女生的数量分别是多少?

    通常我们这么写:
    select count(*) from 表 where 性别 = 男;
    select count(*) from 表 where 性别 = 女;

    要想显示到一起还要union一下,太麻烦了

    用decode呢,只需要一句话

    select sum(decode(性别,男,1,0)),sum(decode(性别,女,1,0)) from 表

    eg:

    select sum(decode(siteno,'LT',1,0)),sum(decode(siteno,'SZ',1,0)) from facd605;
    
    select sum(case siteno when 'LT' then 1 else 0 end),sum(case siteno when 'SZ' then 1 else 0 end) from facd605;

    总结

    以上就是本文关于oracle中decode函数的使用方法示例的全部内容,希望对大家有所帮助。欢迎参阅:Oracle中游标Cursor基本用法详解、oracle数据库ORA-01196错误解决办法分享、oracle常见故障类别及规划解析等,感谢朋友们对本站的支持!

    您可能感兴趣的文章:
    • oracle中的greatest 函数和 least函数示例代码
    • oracle中的一些常用函数及示例
    • oracle数据库实现获取时间戳的无参函数
    • Oracle 中Contains 函数的用法
    • Oracle常用函数Trunc及Trunc函数用法讲解
    • Oracle中的translate函数和replace函数的用法详解
    • Oracle 中 decode 函数用法
    • oracle求字符串长度函数length()和hengthb()简介
    • Oracle计算时间差常用函数
    • oracle常用分析函数与聚合函数的用法
    上一篇:Oracle中游标Cursor基本用法详解
    下一篇:Oracle结合Mybatis实现取表TOP 10条数据
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    oracle中decode函数的使用方法示例 oracle,中,decode,函数,的,使用方法,