Oracle Decode函数详解 电脑资料_第1页
Oracle Decode函数详解 电脑资料_第2页
Oracle Decode函数详解 电脑资料_第3页
Oracle Decode函数详解 电脑资料_第4页
Oracle Decode函数详解 电脑资料_第5页
已阅读5页,还剩4页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

Oracle Decode函数详解 电脑资料 Oracle Decode函数详解 select a.ok 合格情况, sum(decode(ame, 计算机, countnum, 0) 人数 from (select ame, case when scgrade when scgrade =60 and scgrade when scgrade =70 and scgrade when scgrade =85 and scgrade =60 and scgrade when scgrade =70 and scgrade when scgrade =85 and scgrade =100 then 优秀 end) a group by a.ok order by a.ok desc 函数介绍 DECODE函数是ORACLE PL/SQL的功能强大的函数之一,目前还只有ORACLE公司的SQL提供了此函数,其它数据库厂商的SQL实现还没有此功能, 关于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数据字典视图 _, select sid,serial#,username, DECODE(mand, 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.每月、季、半年及年终都要求将经办行 变为“列”给出个月的明细报表: 经办行:城西区 城东区 月份: xx.01 xxxx1.xx xxxxx2.xx xx.02 xxxx3.xx xxxxx4.xx 。 。 。 。 。 。 原来的数据顺序是: 城西区xx.01 xxxxx1.xx 城东区xx.01 xxxxx2.xx 城西区xx.02 xxxxx3.xx 城东区xx.02 xxxxx4.xx 住房公积金系统记录职工的每月交缴名细的pay_lst表结构是: bank_code varchar2(6)NOT NULL, - 经办行代码 a_no varchar2(15) not null, - 单位代码(单位帐号) emp_a_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 ( b

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论