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 函数的用法相关推荐

  1. decode函数的用法(decode函数的用法python二进制)

    DECODE()函数用法是什么? 例如:表table_subject,有subject_name列.要求按照:语.数.外的顺序进行排序.这时,就可以非常轻松的使用Decode完成要求了. select ...

  2. SQL中decode函数的用法

    SQL中decode函数的用法 2008-07-30 17:11:14 本文已公布到博客频道职场·创业分类 DECODE函数是ORACLE PL/SQL是功能强大的函数之一,目前还只有ORACLE公司 ...

  3. python decode函数的用法_oracle decode函数使用方法

    以下是一个简单测试,用于说明Decode函数的用法: SQL> create table t as select username,default_tablespace,lock_date fr ...

  4. sql中decode(...)函数的用法

    sql中decode(...)函数的用法 相当于if语句 decode函数比较1个参数时 SELECT ID,DECODE(inParam,'beComparedParam','值1' ,'值2') ...

  5. python decode函数的用法_Oracle DECODE函数的用法详解

    Oracle DECODE函数 使用方法: 1.比较大小 select decode(sign(变量1-变量2),-1,变量1,变量2) from dual; --取较小值 sign()函数根据某个值 ...

  6. 【转】SQL decode 函数的用法

    decode(字段|表达式,条件1,结果1,条件2,结果2,...,条件n,结果n,缺省值): --缺省值可以省略 表示如果 字段|表达式 等于 条件1 时,DECODE函数的结果返回 条件1 ,.. ...

  7. 数据库中自定义排序规则,Mysql中自定义字段排序规则,Oracle中自定义字段排序规则,decode函数的用法,field函数的用法

    数据库中自定义排序 场景:有一张banner表,表中有一个status字段,有0, 1, 2三个状态位,我想要 1,0,2的自定义排序(这里是重点),然后再进行之上对sequence字段进行二次排序( ...

  8. python decode函数的用法_decode函数的用法

    DECODE函数是ORACLE PL/SQL是功能强大的函数之一,目前还只有ORACLE公司的SQL提供了此函数,其他数据库厂商的SQL实现还没有此功能.DECODE有什么用途呢? 先构造一个例子,假 ...

  9. oracle decode函数什么意思,oracle decode函数的用法

    oracle decode函数,不管查询的结果是否满足'PRIMARY',参数中的select语句还是会执行的,通过查看执行计划就知道 set autotrace traceonly select d ...

最新文章

  1. session_start() 对 HTTP_REQUEST扩展/fsockopen函数 的影响
  2. 一个开源小项目,如何使用「分类网络」实现排球追踪
  3. 《SSM框架实战》 整合 Freemarker
  4. Kafka安装及部署
  5. 关于CMR和SMR技术硬盘的选择
  6. 珍藏 | 近200篇机器学习与深度学习经典论文整理
  7. Revit二次开发: 文件损坏
  8. uva 12230 - Crossing Rivers(概率)
  9. Dev-Cpp下载和安装步骤
  10. SIP协议错误代码code大全(中英文对照)
  11. 162手写板合封芯片专用IC输出可达50V外围简单SOP8封装
  12. 电商、数字化下的中国书店
  13. mov格式的视频转换mp4?视频格式转换这样做
  14. Appium+python自动化(四十一)-Appium自动化测试框架综合实践 - 即将落下帷幕(超详解)
  15. 美国研究生院计算机数据科学排名,2021美国硕士计算机专业排名
  16. 删除字符串中的数字字符
  17. Android APP全局黑白化实现方案
  18. 他,是碾压爱迪生的科技天才!尼古拉特斯拉的一生竟是这样...
  19. java接口汽车品牌,88_熟练掌握ES Java API_对汽车品牌进行全文检索、精准查询和前缀搜索...
  20. 斯诺登最新泄漏文档:揭秘美国秘密监控基地——澳大利亚“松树谷”

热门文章

  1. java choice控件_hi,请教JAVA中AWT的choice(下拉列表)控件的使用问题~~~
  2. 【WINDOWS / DOS 批处理】choice命令之参数完整解析
  3. 2022年低压电工考试模拟100题模拟考试平台操作
  4. CO40/CO41转生产订单下达时不能创建采购申请
  5. Filter-policy工具理论与实践
  6. 日语能力三级语法汇总
  7. 如何在Word中自由移动图片?在 Microsoft Word 中自由移动图片的方法!
  8. 今日金融词汇---品牌溢价
  9. C# 如何打印Word文档
  10. office 2010 官方教程下载 附带视频教程