`

decode函数使用

阅读更多
DECODE函数,是ORACLE公司的SQL软件ORACLE PL/SQL所提供的特有函数计算方式,以其简洁的运算方式,可控的数据模型和灵活的格式转换而闻名。

函数介绍
关于DECODE1 DECODE 中的if-then-else逻辑
2 DECODE 的简单例子
3 DECODE实现表的转置
函数介绍
关于DECODE 1 DECODE 中的if-then-else逻辑
2 DECODE 的简单例子
3 DECODE实现表的转置
展开 编辑本段函数介绍
  DECODE函数是ORACLE PL/SQL的功能强大的函数之一,目前还只有ORACLE公司的SQL提供了此函数,其它数据库厂商的SQL实现还没有此功能。DECODE有什么用途呢? 先构造一个例子,假设我们想给智星职员加工资,其标准是:工资在8000元以下的加20%;工资在8000元或以上的加15%,通常的做法是,先选出记录中的工资字段值 --->select salary into var-salary from employee,然后对变量var-salary用if-then-else或 case when then else end之类的流控制语句进行判断。 如果用DECODE函数,那么我们就可以把这些流控制语句省略,通过SQL语句就可以直接完成。如下:   select decode(sign(salary - 8000),1,salary*1.15,-1,salary*1.2,salary*1.15) from employee 是不是很简洁? DECODE的语法:DECODE(value,if1,then1,if2,then2,if3,then3,...,else),表示如果value等于if1时,DECODE函数的结果返回then1,...,如果不等于任何一个if值,则返回else。初看一下,DECODE 只能做等于测试,但刚才也看到了,我们通过一些函数或计算替代value,是可以使DECODE函数具备大于、小于或等于功能。
编辑本段关于DECODE
  DECODE是Oracle公司独家提供的功能,它是一个功能很强的函数。它虽然不是SQL的标准,但对于性能非常有用。到目前,其他的数据库供应商还不能提供类似DECODE的功能,甚至有的数据库的供应商批评Oracle的SQL不标准。实际上,这种批评有些片面或不够水平。就象有些马车制造商抱怨亨利·福特的“马车”不标准一样。
1 DECODE 中的if-then-else逻辑
  在逻辑编程中,经常用到If – Then –Else 进行逻辑判断。在DECODE的语法中,实际上就是这样的逻辑处理过程。它的语法如下:   DECODE(value, if1, then1, if2,then2, if3,then3, . . . else )   Value 代表某个表的任何类型的任意列或一个通过计算所得的任何结果。当每个value值被测试,如果value的值为if1,Decode 函数的结果是then1;如果value等于if2,Decode函数结果是then2;等等。事实上,可以给出多个if/then 配对。如果value结果不等于给出的任何配对时,Decode 结果就返回else 。   需要注意的是,这里的if、then及else 都可以是函数或计算表达式。
2 DECODE 的简单例子
  Oracle系统中就有许多数据字典是使用decode 思想设计的,比如记录会话信息的V$SESSION数据字典视图就是这样。我们从《Oracle8i/9i Reference》资料中了解到,当用户登录成功后在V$SESSION中就有该用户的相应记录,但用户所进行的命令操作在该视图中只记录命令的代码(0—没有任何操作,2—Insert…),而不是具体的命令关键字。因此,我们需要了解当前各个用户的名字及他们所进行的操作时,要用下面命令才能得到详细的结果:   
select sid,serial#,username,   
DECODE(command,   0,’None’,   
2,’Insert’,   
3,’Select’,   
6,’Update’,   
7,’Delete’,   
8,’Drop’,   
‘Other’) cmmand   
from v$session where username is not null;
3 DECODE实现表的转置
  数据库中的表是由列和行构成的一个二维表。一般列在任何数据库中都是有限的数量,而行的变化较大,如果表很大,行的数量可能大上千万行。同一列的不同行可能有不同的值,而且不是预先定义的。   
例:住房公积金报表置换实例:   
1.各个单位在本地经办行进行开户,开户就是将单位的基本信息和职工信息的进行登记;  2.每月各个单位的会计到经办行交缴本单位的所有职工的住房公积金,系统记录有每个职工的交缴明细并在每条记录上记录有经办行的代码;   
3.每月、季、半年及年终都要求将经办行 变为“列”给出个月的明细报表:   
经办行:城西区 城东区   
月份:   2001.01 xxxx1.xx xxxxx2.xx   2001.02 xxxx3.xx xxxxx4.xx   。 。 。 。 。 。   
原来的数据顺序是:   
城西区2001.01 xxxxx1.xx   
城东区2001.01 xxxxx2.xx   
城西区2001.02 xxxxx3.xx   
城东区2001.02 xxxxx4.xx   
住房公积金系统记录职工的每月交缴名细的pay_lst表结构是:   
bank_code varchar2(6)NOT NULL, -- 经办行代码   
acc_no varchar2(15) not null, -- 单位代码(单位帐号)   
emp_acc_no varchar2(20) not null, -- 职工帐号   
tran_date date not null, -- 交缴日期   
tran_val Number(7,2) not null, -- 交缴额   
sys_date date default sysdate, --系统日期   
oper_id varchar2(10) --操作员代码   
这样的表结构,一般按照将经办行作为行(row)进行统计是很容易的,但是如果希望将经办行变为列(column)这样的格式来输出就有困难。如果用DECODE函数来处理则变得很简单:   我们创建一个视图来对目前的pay_lst表进行查询。
将经办行代码变为一些具体的经办行名称即可:   
CREATE OR REPLACE VIEW bank_date_lst AS   
Select to_char(tran_date,’yyyy.mm’),   SUM( DECODE ( bank_code,’001’, tran_val,0 )) 城西区,   SUM( DECODE ( bank_code,’002’, tran_val,0 )) 城南区,   SUM( DECODE ( bank_code,’003’, tran_val,0 )) 城东区  
FROM pay_lst   GROUP BY to_char(tran_date,’yyyy.mm’);   
建立视图后,可直接对该视图进行查询就可按照列显示出结果。
分享到:
评论

相关推荐

    关于decode函数的使用

    ### 关于decode函数的使用详解 #### 函数概述 `decode()`函数在SQL语言中是一种常用的条件函数,它可以根据指定的表达式返回不同的值。这种功能对于数据转换、分类统计等场景非常有用。 #### 主要作用 `decode()`...

    decode函数.docx

    decode 函数也可以与其他函数结合使用,例如 LPAD 函数,可以实现一些复杂的字符串处理,例如: ```sql SELECT LPAD(DECODE(COUNT(记录编号),0,1,MAX(TO_NUMBER(记录编号)+1)),14,'0') 记录编号 FROM tetdmis ``` ...

    关于oracle decode函数的用法

    在商品销售表`sale`的转化示例中,使用了DECODE函数来将每月的销售数据从行转为列,形成年份为行,各月销售金额为列的新结构。例如,为了计算每年1月的销售总额,使用了`SUM(DECODE(SUBSTRB(month,5,2),'01',sell,0)...

    decode函数借鉴.pdf

    DECODE 函数还可以用来实现数据的格式转换,例如,在住房公积金报表置换实例中,我们可以使用 DECODE 函数来实现数据的转换和处理。 DECODE 函数是 Oracle 公司独家的功能强大的函数,它提供了简洁的运算方式、可控...

    decode函数.pdf

    不过,考虑到给定文件标题和描述的限定,“decode函数.pdf”,在这里我们主要聚焦于Decode函数的使用和功能。Decode函数在Oracle SQL和PL/SQL中的重要性不可忽视,它是实现条件逻辑判断的关键工具之一。

    decode函数[归类].pdf

    在示例中,对于工资调整的问题,DECODE函数可以这样使用: ```sql SELECT DECODE(SIGN(salary - 8000), >=0, salary * 1.15, -- 工资在8000元以上,加15% , salary * 1.2, -- 工资在8000元以下,加20% salary) -...

    ORACLE 列转行 DECODE函数用法

    下面我们将详细讲解DECODE函数的使用方法以及如何在列转行操作中应用它。 DECODE函数的基本语法如下: ```sql DECODE(column, value1, result1, value2, result2, ..., default_result) ``` 这里`column`是要检查的...

    Oracle 中 decode 函数用法

    DECODE函数还可以与其他函数结合使用,例如`LPAD`,用于在输出前填充零,确保数据的格式一致。例如,如果你有一个自增的主键,想在输出时自动加1并前面补零,可以这样做: ```sql SELECT LPAD(DECODE(COUNT(记录编号...

    oracle的decode函数

    ### Oracle的DECODE函数详解 #### 一、DECODE函数简介 在Oracle数据库中,`DECODE`函数是一种非常实用的条件判断函数,其功能类似于编程语言中的`IF`语句。通过比较输入值与一系列预设值,该函数能够根据匹配情况...

    Decode函数的用法(视图)

    要按学生ID分别显示语文、数学、英语的成绩,可以创建一个视图,使用`DECODE`函数将成绩列转换为单独的列。 创建视图的脚本如下: ```sql CREATE OR REPLACE VIEW cjd AS SELECT sid, DECODE(kcbm, '语文', cj,...

    Oracle中Decode()函数使用技巧

    下面将详细介绍Oracle Decode()函数的使用技巧。 1. **基本语法**: Decode()函数的基本语法如下: ``` DECODE(source, value1, result1, value2, result2, ..., default_value) ``` 其中,`source`是要检查的...

    用JavaScript实现PHP的urldecode/urldecode函数

    这个是 utf-8版本的 js实现 php的 urlencode() 和 urldecode()两个函数的功能。 在传送cookie的时候 在 php端实现 url编码 但要用 js来解码cookie的时候 就出现汉字不能不能识别的问题 这个 js 很好的解决

    decode函数与case when 的妙用

    在阅读博客文章《decode函数与case when 的妙用》时,作者可能分享了一些具体的示例和使用技巧,帮助我们更好地理解和掌握这两种方法。通过学习和实践,我们可以将这些知识应用于日常的数据库操作,优化数据处理流程...

    decode解码函数

    在ASP(Active Server Pages)环境中,可以使用内置的`Server.URLEncode`函数进行URL编码,而解码则可以使用`Server.URLDecode`函数。`Server.URLDecode("编码后的字符串")`会返回解码后的原始字符串。例如,如果有...

    Oracle DECODE函数语法使用介绍

    Oracle DECODE函数功能很强,下面就为您详细介绍Oracle DECODE函数的用法,希望可以让您对Oracle DECODE函数有更多的了解。 Oracle DECODE函数 Oracle DECODE函数是Oracle公司独家提供的功能,它是一个功能很强的...

    gzip124 decode函数说明

    `gzip124` 是一个压缩工具,其解码功能主要由 `decode` 或 `inflate_codes` 函数实现。这个函数是 gzip 解压过程中的关键部分,负责将压缩的二进制数据转换回原始格式。在理解这个过程之前,我们需要先了解一下 ...

    oracle中decode函数的使用方法

    `DECODE`函数的灵活性在于它可以处理多个可能的值,并且可以与其它函数如`LPAD`结合使用,增加数据处理的复杂性,如在生成自动递增的序列号并添加前导零: ```sql SELECT LPAD(DECODE(COUNT(记录编号), 0, 1, MAX...

Global site tag (gtag.js) - Google Analytics