精华内容
下载资源
问答
  • decode(条件,值1,返回值1,值2,返回值2,…值n,返回值n,缺省值) 该函数的含义如下: IF 条件=值1 THEN  RETURN(翻译值1) ELSIF 条件=值2 THEN  RETURN(翻译值2)  ...... ELSIF 条件=值n THEN  RETURN(翻译值n) ...
  • Decode函数的语法结构如下: 代码如下:decode (expression, search_1, result_1)decode (expression, search_1, result_1, search_2, result_2)decode (expression, search_1, result_1, search_2, result_2, …., ...
  • DECODE是Oracle公司独家提供的功,该函数功能强大,下文对DECODE函数的语法作了详尽的阐述,供您参考学习
  • NULL 博文链接:https://hcty31.iteye.com/blog/1119556
  • decode函数

    2020-07-29 19:28:47
    文章来源:decode函数的使用 decode的几种用法 1.使用decode判断字符串是否一样 decode(value,if 1,then 1,if 2,then 2,if 3,then 3,……,else) 含义为: if 条件 = 值1 then return(value 1) if 条件 = 值2 then ...

    文章来源:decode函数的使用

    decode的几种用法

    1.使用decode判断字符串是否一样

    decode(value,if 1,then 1,if 2,then 2,if 3,then 3,……,else)
    含义为:

    if 条件 =1 then
    	return(value 1)
    if 条件 =2 then
    	return(value 2)
    if 条件 =3 then
    	return(value 3)
    ……
    else
    	return(default)
    end if
    
    

    栗子:

    >select empno,decode(empno,7396,'smith',7499,'allen',7521,'ward',7566,'jones','unknow') as name from emp where rownum <= 6;
    >7369 smith
     7499 allen
     7521 ward
     7566 jones
     7654 unknow
     7698 unknow
    

    2.使用decode比较大小

    如下,和min起的作用是一样的。

    select decode (sign(var1-var2),-1,var1,var2) from dual

    其中 sign是符号函数,若函数内为负数返回-1,若为正数返回1,若为0返回0.若把-1改为1,则作用和max相同。
    栗子:

    # 取小的数
    >select decode(sign(100-90),-1,100,90) from daul;
    >90
    
    #取大的数
    >select decode(sign(100-90),1,100,90);
    >100
    
    

    3.使用decode函数分段

    工资大于等于10000为高薪,小于10000且大于等于5000为中等,工资小于5000且大于等于1000为低薪,小于1000为极低薪。
    栗子

    >select ename,sal,
    	   decode(sign(sal-10000),
    	   		  1,'high sal',
    	   		  0,'high sal',
    	   		  -1,decode(sign(sal-5000),
    	   		  		    1,'mid sal',
    	   		  		    0,'mid sal',
    	   		  		    -1,decode(sign(sal-1000),
    	   		  		    		  1,'low sal',
    	   		  		    		  0,'low sal',
    	   		  		    		  -1,'best low sal')))
     from emp;
    >smith 800   best low sal
     allen 1600  low sal
     ward  5200  mid sal
     jones 15300 high sal	  	
     james 5000  mid sal	    
    

    4.利用decode实现表或者视图的行列转换

    栗子

    >select 
    	sum(decode(ename,'smith',sal,0) smith,
    	sum(decode(ename,'allen',sal,0) allen,
    	sum(decode(ename,'ward',sal,0) ward,
     from emp;
     > smith allen ward
        800  1600  5200
    

    5.使用decode函数根据表达式来搜索字符串

    使用方法decode(expression,search_1,result_1,search_2,result_2,……,search_n,result_n,default)
    其中decode函数用来比较表达式,和搜索字符串,如果匹配,则返回结果;如果不匹配,返回default值;如果未定义default值,则返回空值。

    栗子

    >select ename,
    		decode(instr(ename,'s'),0,'不含有s','含有s') as info
     from emp;
    >smith 含有s
     allen 不含有s
     ward  不含有s
    

    #over,明天写窗口函数。

    展开全文
  • decode函数.docx

    2013-01-31 09:44:53
    decode函数.docx
  • DECODE函数

    2019-01-08 03:58:59
    DECODE函数相当于一条件语句(IF),它将输入数值与函数中的参数列表相比较,根据输入值返回一个对应值。函数的参数列表是由若干数值及其对应结果值组成的若干序偶形式。当然,如果未能与任何一个实参序偶匹配成功,则...

        DECODE函数相当于一条件语句(IF),它将输入数值与函数中的参数列表相比较,根据输入值返回一个对应值。函数的参数列表是由若干数值及其对应结果值组成的若干
    序偶形式。当然,如果未能与任何一个实参序偶匹配成功,则函数也有默认的返回值。区别于SQL的其它函数,DECODE函数还能识别和操作空值。
        其具体的语法格式如下:
          DECODE(input_value,value,result[,value,result...][,default_result]);
        其中:
         input_value试图处理的数值。DECODE函数将该数值与一系列的序偶相比较,以决定最后的返回结果value是一组成序偶的数值。如果输入数值与之匹配成功,则相应的结果将被返回。
         对应一个空的返回值,可以使用关键字NULL于之对应;
         result是一组成序偶的结果值;
         default_result未能与任何一序偶匹配成功时,函数的返回的默认值。
    下面以例子说明:

    利用DECODE函数求出基于不同职位的(job)每个员工加薪后的工资值。涉及的表名:emp
    SQL> select ename "Name",job,sal "Salary",
      2         DECODE(job,'SALESMAN',sal*1.15,
      3                'CLERK', sal*1.20,
      4                'ANALYST',sal*1.25,
      5                         sal*1.40) "New Salary"
      6   from emp
      7  order by job;
    
    Name             JOB                Salary New Salary
    -------   ---------        ---------- ----------
    SCOTT             ANALYST              3000     3750
    FORD             ANALYST              3000     3750
    MILLER           CLERK                1300     1560
    JAMES             CLERK                950       1140
    SMITH             CLERK                800       960
    ADAMS             CLERK                1100     1320
    BLAKE             MANAGER              2850     3990
    JONES             MANAGER              2975     4165
    CLARK             MANAGER              2450     3430
    KING             PRESIDENT            5000     7000
    TURNER           SALESMAN              1500     1725
    MARTIN           SALESMAN              1250   1437.5
    WARD             SALESMAN              1250   1437.5
    ALLEN             SALESMAN              1600     1840
    
    已选择14行。

    在上面例子查询语句中,DECODE函数执行的步骤如下:
    (1)、当job为SALESMAN时DECODE函数返回表达式sal*1.5的值,否则,执行(2);
    (2)、当job为CLERK时DECODE函数返回表达式sal*1.20的值,否则,执行(3);
    (3)、当job为ANALYST时DECODE函数返回表达式sal*1.25的值,否则,执行(4);
    (4)、DECODE函数返回表达式sal*1.40的值。

    最近10天中每天日志切换的量(即可分析10天的波度,又可分析24小时内,可很容易看出异常情况)
    SELECT SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH:MI:SS'),1,5) Day,
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'00',1,0)) H00,
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'01',1,0)) H01, 
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'02',1,0)) H02,
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'03',1,0)) H03,
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'04',1,0)) H04,
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'05',1,0)) H05,
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'06',1,0)) H06,
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'07',1,0)) H07,
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'08',1,0)) H08,
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'09',1,0)) H09,
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'10',1,0)) H10,
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'11',1,0)) H11, 
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'12',1,0)) H12,
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'13',1,0)) H13, 
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'14',1,0)) H14,
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'15',1,0)) H15, 
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'16',1,0)) H16, 
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'17',1,0)) H17, 
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'18',1,0)) H18, 
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'19',1,0)) H19, 
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'20',1,0)) H20, 
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'21',1,0)) H21,
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'22',1,0)) H22 , 
           SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'23',1,0)) H23, 
           COUNT(*) TOTAL 
    FROM v$log_history  a  
       where first_time>=to_char(sysdate-11)
    GROUP BY SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH:MI:SS'),1,5) 
    ORDER BY SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH:MI:SS'),1,5) DESC;

     

    展开全文
  • decode函数用法

    2021-05-11 14:17:41
    decode 函数在sql中作用相当于case when,意思是根据某一字段的值作为条件,根据这个条件进行输出。 例如 case when 语句: 例如:根据身份证判定该员工是否是男女,从而实现对性别的更新。 身份证号的第17位数字,...

    decode 函数在sql中作用相当于case when,意思是根据某一字段的值作为条件,根据这个条件进行输出。

    例如 case when 语句:

    例如:根据身份证判定该员工是否是男女,从而实现对性别的更新。
    身份证号的第17位数字,奇数为男性,偶数为女性
    SEX CHAR(1) NOT NULL, --** 性别: 1 男,2 女

    UPDATE table_name SET 
    SEX = (CASE WHEN mod(identifynumber[17],2) = '1' THEN '1' ELSE  '2' end) 
    WHERE condition;
    

    相当于 decode () 函数:

    UPDATE table_name SET 
    SEX =  decode(mod(to_number(substr(identifynumber, 17, 1)),2),0,'2','1')
    WHERE condition;
    

    decode函数用法:

    decode函数的两种形式

    第一种形式:

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

    第二种形式:

    decode(字段或字段的运算,值1,值2,值3)

    这个函数运行的结果是,当字段或字段的运算的值为值1时,该函数返回值2,否则返回值3(值1,值2,值3也可以是表达式)


    DECODE 与CASE WHEN 的比较:

    1、DECODE 只有Oracle、informix才有,其它数据库不支持;
    2、CASE WHEN的用法, Oracle、SQL Server、 MySQL、 informix、都支持;
    3、DECODE 只能用做相等判断,但是可以配合sign函数进行大于,小于,等于的判断,CASE when可用于=,>=,<,<=,<>,is null,is not null 等的判断;
    4、DECODE 使用其来比较简洁,CASE 虽然复杂但更为灵活;
    5、另外,在decode中,null和null是相等的,但在case when中,只能用is null来判断。

    展开全文
  • 代码如下:‘================================================ ‘函数名:URLDecode ‘作 用:URL解码 ‘================================================ Function URLDecode(ByVal urlcode) Dim start,final,...
  • Oracle decode函数

    万次阅读 多人点赞 2019-09-01 12:54:20
    一 两种语法格式 ...1 decode(expression,value,result1,result2) 如果expression=value,则输出result1,否则输出result2 例子: (1+2=3,输出a) (1+2≠4,输出b) 2 decode(expre...

    一 两种语法格式

    1 decode(expression,value,result1,result2)

       如果expression=value,则输出result1,否则输出result2

       例子:

                

               (1+2=3,输出a)

                 

                (1+2≠4,输出b)

    2 decode(expression,value1,result1,value2,result2,value3,result3......,default)

       如果expression=value1,则输出result1,expression=value2,输出reslut2,expression=value3,输出result3,

       若expression不等于所列出的所有value,则输出为default

      例子:

                

                (score=100,输出'NO.1',score='90',输出‘NO.2’,score='70',输出‘NO.3’,其他值输出'Other')

     

    二 应用

    1 使用decode函数分段

       将成绩表中分数大于90分的分为优秀,80~90分为良好,70~80分为中等,60~70分为及格,60分以下为不及格。

               

              (sign()函数的作用是,判断参数的值大于0则返回1,等于0则返回0,小于0则返回-1;

                 如图,当socre大于或等于90时,socre-90>=0,sign()函数返回1或0,则输出‘优秀’,

                 在score-90<0的情况下,再判断socre-80,socre-80>=0,sign()函数返回1或0,则输出‘良好’,

                 以此类推,用decode()的嵌套配合sign()函数来实现对分数的分段以及相应的输出,

                 最后60分以下的就default为‘不及格’就可以了,可以看到我们的Tony老师的分数就不及格了)

     

    2 使用decode函数对表做行列转换

                 

    如图所示,有一张三个科目的成绩表,各科目名称和相应的分数呈现在行中,

    现想将各科目名称转换为列名,每列的内容为对应科目的分数。

                 

                 (如图,先用decode函数判断subject为Chinese时,输出score,不为Chinese时,输出为NULL,

                    因为共有三个科目,所以输出其中一个科目的分数时,其他科目的分数为NULL,这里只需要

                    用sum()函数来实现聚合的作用,将空值去除掉就可以了)

                  

                (sum()函数分别将name为John的每个列的值相加,如Chinese列,80+NULL+NULL=80,

                  再将name为Will的每个列的值相加,然后group by将name分组,最终达到如上图聚合的效果)

     

    以上为个人学习总结,将持续更新

    对Oracle有兴趣的朋友可以加微信qq918858589

    有学习资料和工作经验可供交流,谢谢!

     

    展开全文
  • decode函数的用法

    千次阅读 2019-04-22 14:34:30
    DECODE(value, if1, then1, if2,then2, if3,then3, . . . else ) SQL测试: ...应用 1、使用decode函数比较大小 Select decode(sign(var1-var2),-1,var1,var2) from dual ---取较小值 Select de...
  • Oracle函数之DECODE函数

    千次阅读 2019-05-06 17:21:04
    DECODE 函数将 expr 与 search 的值逐个比较。如果 expr 与 search 值相等,Oracle 返回 search 相应的 result。如果 expr 与 search 值都不匹配,Oracle 返回 default,如果没有函数中没有赋值 default,Oracle ...
  • <p>MySQL不能用encode和decode函数吗?使用函数说函数不存在。</p>
  • decode函数的妙用

    2020-04-09 07:50:00
    ID NAME ---- ------- 2 其实,Tom大叔和Darl的经典著作《Oracle编程艺术-深入理解数据库体系结构》中提到了一种更为简单的操作,使用decode函数, 如果decode函数中expr和search相等,则Oracle返回result,如果...
  • php session_decode函数怎么用? 作用:解码会话数据 语法: bool session_decode ( string $data ) 参数: data, 编码后的数据。 说明: session_decode() 对 $data 参数中的已经序列化的会话数据进行解码, 并且...
  • sql中的decode函数

    千次阅读 2020-04-25 16:19:23
    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...
  • 主要介绍了php自定义urlencode,urldecode函数,实例分析了php字符串转码的技巧,具有一定参考借鉴价值,需要的朋友可以参考下
  • 使用DECODE实现统计,是比较常用的。 但是在遇到需要组合条件进行统计时,有时却不如case when 或者另建视图好用。 可是有时就想用DECODE,咋办? 这里给大家介绍一下DECODE如何实现组合条件查询,一句SQL查询一张...
  • 很多朋友说JavaScript的decodeURI函数也可以实现,但有bug所有呢,下面看下下面的函数,经过测试使用暂时没什么问题,我在之前的文章说过,这个和php的urldecode函数根本不是一回事。下面是我根据高人的代码改写的...
  • 要求 : 让用hive实现类似orale的decode函数功能。 Oracle的decode函数语法:DECODE(value,if1,then1,if2,thne2,if3,then3,...else)。 首先涉及到的问题是输入参数的动态化,decode函数要求输入函数是偶数个,...
  • 本篇文章主要是对PHP json_decode函数进行了介绍,需要的朋友可以过来参考下,希望对大家有所帮助
  • 今天写代码的时候,需要用到json_decode函数,发现php5.2以前的版本没有集成这个函数,不过我们可以通过自定义函数实现。 复制代码 代码如下:function json_decode2($json){$comment = false;$out = ‘$x=’;for ($i...
  • Oracle中decode函数用法解析以及常用场景

    万次阅读 多人点赞 2019-04-02 16:41:04
    1.decode函数的两种形式 第一种形式 含义解释: decode(条件,值1,返回值1,值2,返回值2,…值n,返回值n,缺省值) 该函数的含义如下: IF 条件=值1 THEN  RETURN(翻译值1) ELSIF 条件=值2 THEN  RETURN(翻译值2)  ......

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 156,777
精华内容 62,710
关键字:

decode函数