Decode 函数的用法
1.根据己知值排序
select a,b
from c where a in (3,2,4,1)
order by decode(a,3,1,2,2,4,3,1,4)
2.比较大小
select decode(sign(变量1-变量2),-1,变量1,变量2) from dual; --取较小值
sign()函数根据某个值是0、正数还是负数,分别返回0、1、-1
例如:
变量1=10,变量2=20
则sign(变量1-变量2)返回-1,decode解码结果为“变量1”,达到了取较小值的目的。
3.decode函数进行多值判断
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, ...., search_n, result_n)decode (expression, search_1, result_1, default)decode (expression, search_1, result_1, search_2, result_2, default)decode (expression, search_1, result_1, search_2, result_2, ...., search_n, result_n, default)
在逻辑编程中,经常用到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 都可以是函数或计算表达式。
decode函数比较表达式和搜索字,如果匹配,返回结果;如果不匹配,返回default值;如果未定义default值,则返回空值。
以下是一个简单测试,用于说明Decode函数的用法:
SQL> create table t as select username,default_tablespace,lock_date from dba_users;
Table created
SQL> select * from t;
USERNAME DEFAULT_TABLESPACE LOCK_DATE
------------------------------ ------------------------------ -----------
SYS SYSTEM
SYSTEM SYSTEM
DBSNMP SYSTEM
SCOTT SYSTEM
OUTLN SYSTEM 2007-7-30 1
WMSYS SYSTEM 2007-7-30 1
ORDSYS SYSTEM 2007-7-30 1
ORDPLUGINS SYSTEM 2007-7-30 1
MDSYS SYSTEM 2007-7-30 1
CTXSYS DRSYS 2007-7-30 1
XDB XDB 2007-7-30 1
ANONYMOUS XDB 2007-7-30 1
WKSYS DRSYS 2007-7-30 1
WKPROXY DRSYS 2007-7-30 1
ODM ODM 2007-7-30 1
ODM_MTR ODM 2007-7-30 1
OLAPSYS CWMLITE 2007-7-30 1
RMAN TOOLS 2007-7-30 1
HR EXAMPLE 2007-7-30 1
OE EXAMPLE 2007-7-30 1
USERNAME DEFAULT_TABLESPACE LOCK_DATE
------------------------------ ------------------------------ -----------
PM EXAMPLE 2007-7-30 1
SH EXAMPLE 2007-7-30 1
QS_ADM EXAMPLE 2007-7-30 1
QS EXAMPLE 2007-7-30 1
QS_WS EXAMPLE 2007-7-30 1
QS_ES EXAMPLE 2007-7-30 1
QS_OS EXAMPLE 2007-7-30 1
QS_CBADM EXAMPLE 2007-7-30 1
QS_CB EXAMPLE 2007-7-30 1
QS_CS EXAMPLE 2007-7-30 1
30 rows selected
SQL> select username,decode(lock_date,null,'unlocked') status from t;
USERNAME STATUS
------------------------------ --------
SYS unlocked
SYSTEM unlocked
DBSNMP unlocked
SCOTT unlocked
OUTLN
WMSYS
ORDSYS
ORDPLUGINS
MDSYS
CTXSYS
XDB
ANONYMOUS
WKSYS
WKPROXY
ODM
ODM_MTR
OLAPSYS
RMAN
HR
OE
USERNAME STATUS
------------------------------ --------
PM
SH
QS_ADM
QS
QS_WS
QS_ES
QS_OS
QS_CBADM
QS_CB
QS_CS
30 rows selected
资料引用:http://www.knowsky.com/347361.html
4. 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’);
建立视图后,可直接对该视图进行查询就可按照列显示出结果。
5.转换命令代码 易读化
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;
Decode 函数的用法相关推荐
- decode函数的用法(decode函数的用法python二进制)
DECODE()函数用法是什么? 例如:表table_subject,有subject_name列.要求按照:语.数.外的顺序进行排序.这时,就可以非常轻松的使用Decode完成要求了. select ...
- SQL中decode函数的用法
SQL中decode函数的用法 2008-07-30 17:11:14 本文已公布到博客频道职场·创业分类 DECODE函数是ORACLE PL/SQL是功能强大的函数之一,目前还只有ORACLE公司 ...
- python decode函数的用法_oracle decode函数使用方法
以下是一个简单测试,用于说明Decode函数的用法: SQL> create table t as select username,default_tablespace,lock_date fr ...
- sql中decode(...)函数的用法
sql中decode(...)函数的用法 相当于if语句 decode函数比较1个参数时 SELECT ID,DECODE(inParam,'beComparedParam','值1' ,'值2') ...
- python decode函数的用法_Oracle DECODE函数的用法详解
Oracle DECODE函数 使用方法: 1.比较大小 select decode(sign(变量1-变量2),-1,变量1,变量2) from dual; --取较小值 sign()函数根据某个值 ...
- 【转】SQL decode 函数的用法
decode(字段|表达式,条件1,结果1,条件2,结果2,...,条件n,结果n,缺省值): --缺省值可以省略 表示如果 字段|表达式 等于 条件1 时,DECODE函数的结果返回 条件1 ,.. ...
- 数据库中自定义排序规则,Mysql中自定义字段排序规则,Oracle中自定义字段排序规则,decode函数的用法,field函数的用法
数据库中自定义排序 场景:有一张banner表,表中有一个status字段,有0, 1, 2三个状态位,我想要 1,0,2的自定义排序(这里是重点),然后再进行之上对sequence字段进行二次排序( ...
- python decode函数的用法_decode函数的用法
DECODE函数是ORACLE PL/SQL是功能强大的函数之一,目前还只有ORACLE公司的SQL提供了此函数,其他数据库厂商的SQL实现还没有此功能.DECODE有什么用途呢? 先构造一个例子,假 ...
- oracle decode函数什么意思,oracle decode函数的用法
oracle decode函数,不管查询的结果是否满足'PRIMARY',参数中的select语句还是会执行的,通过查看执行计划就知道 set autotrace traceonly select d ...
最新文章
- session_start() 对 HTTP_REQUEST扩展/fsockopen函数 的影响
- 一个开源小项目,如何使用「分类网络」实现排球追踪
- 《SSM框架实战》 整合 Freemarker
- Kafka安装及部署
- 关于CMR和SMR技术硬盘的选择
- 珍藏 | 近200篇机器学习与深度学习经典论文整理
- Revit二次开发: 文件损坏
- uva 12230 - Crossing Rivers(概率)
- Dev-Cpp下载和安装步骤
- SIP协议错误代码code大全(中英文对照)
- 162手写板合封芯片专用IC输出可达50V外围简单SOP8封装
- 电商、数字化下的中国书店
- mov格式的视频转换mp4?视频格式转换这样做
- Appium+python自动化(四十一)-Appium自动化测试框架综合实践 - 即将落下帷幕(超详解)
- 美国研究生院计算机数据科学排名,2021美国硕士计算机专业排名
- 删除字符串中的数字字符
- Android APP全局黑白化实现方案
- 他,是碾压爱迪生的科技天才!尼古拉特斯拉的一生竟是这样...
- java接口汽车品牌,88_熟练掌握ES Java API_对汽车品牌进行全文检索、精准查询和前缀搜索...
- 斯诺登最新泄漏文档:揭秘美国秘密监控基地——澳大利亚“松树谷”