ORACLE的sign函数和DECODE函数

比较大小函数 sign数据库

函数语法:
sign(n)
编程

函数说明:
取数字n的符号,大于0返回1,小于0返回-1,等于0返回0session

示例:
1、select sign( 100 ),sign(- 100 ),sign( 0 ) from dual;函数

  SIGN(100) SIGN(-100) SIGN(0)
  ———- ———- ———-
  1 -1 0性能

2、a=10,b=20
  则sign(a-b)返回-1
 
流程控制函数 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或choose case之类的流控制语句进行判断。若是用DECODE函数,那么咱们就能够把这些流控制语句省略,经过SQL语句就能够直接完成。以下:select decode(sign(salary - 8000),>=0,salary*1.15,<0,salary*1.2,salary) from employee 是否是很简洁? DECODE的语法:DECODE(value,if1,then1,if2,then2,if3,then3,...,else),表示若是value等于if1时,DECODE函数的结果返回then1,...,若是不等于任何一个if值,则返回else。初看一下,DECODE 只能作等于测试,但刚才也看到了,咱们经过一些函数或计算替代value,是可使DECODE函数具有大于、小于或等于功能。spa

关于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’);   创建视图后,可直接对该视图进行查询就可按照列显示出结果。
相关文章
相关标签/搜索