博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQL语句decode函数
阅读量:6187 次
发布时间:2019-06-21

本文共 1033 字,大约阅读时间需要 3 分钟。

  今天有个需求,帮财务从系统导出一份统计数据,由于系统设计的比较烂,简单的一个查询语句被搞的比较复杂,用到decode函数来处理,居然还要用到加减法。语句如下:

 
  1. select to_date(substr("DOC_CREATE_TIME", 0,9),'fmdd month yy'),  
  2. fd_mingzi,  
  3. (select  fd_name from sys_org_element where fd_id=fd_bumen),  
  4. fd_ypzhiwei,  
  5. fd_chengshi,  
  6. to_date(substr("FD_TIME", 0,9),'fmdd month yy'),  
  7. decode(fd_xinchoutx,'1','财务', '2','结算','3','采购','4','生产'),  
  8. 9-fd_xcdengj,  
  9. 11-fd_xinji,  
  10. from ekp_ruzhi a,km_review_main b where a.FD_ID = b.FD_ID order by 1 desc; 
  11.   

具体用法:

DECODE函数相当于一条件语句(IF).它将输入数值与函数中的参数列表相比较,根据输入值返回一个对应值。函数的参数列表是由若干数值及其对应结果值组成的若干序偶形式。当然,如果未能与任何一个实参序偶匹配成功,则函数也有默认的返回值。区别于SQL的其它函数,DECODE函数还能识别和操作空值. 

其具体的语法格式如下: 

DECODE(input_value,value,result[,value,result…][,default_result]); 

其中: 

input_value 试图处理的数值。DECODE函数将该数值与一系列的序偶相比较,以决定最后的返回结果 

value 是一组成序偶的数值。如果输入数值与之匹配成功,则相应的结果将被返回。对应一个空的返回值,可以使用关键字NULL于之对应 

result 是一组成序偶的结果值 

default_result 未能与任何一序偶匹配成功时,函数返回的默认值 

下面的例子说明了,如何读取用户CHECKUP表SEAPARK中的BLOOD_TEST_FLAG列下的项目,作为DECODE函数的实参支持值。 

SELECT checkup_type, 

DECODE(blood_test_flag,’Y’,’Yes’,’N’,’No’,NULL,’None’,’Invalid’) 

FROM checkup;

 

转载地址:http://ftada.baihongyu.com/

你可能感兴趣的文章
QTP引用外部脚本路径的设定(三)Instr函数的使用
查看>>
Linux 监控工具之Cacti使用详解(四)
查看>>
机房管理系列之共享打印服务器
查看>>
ORACLE_OCM.MGMT_DB_LL_METRICS报错
查看>>
文件服务器的配置与管理(3) 共享文件夹的创建与使用
查看>>
Windows快捷方式
查看>>
Essential Linux Device Driver附录A . Linux汇编
查看>>
eclipse导入的工程莫名报错误
查看>>
[Android]基于RxJava、RxAndroid的EventBus实现
查看>>
细说Linq之Aggregate
查看>>
font-size:0清除display:inline-block元素换行符间隙实例页面
查看>>
Gradle 提速:每天为你省下一杯喝咖啡的时间
查看>>
《iOS 核心动画高级技巧》笔记
查看>>
前端小知识10点(2019.5.18)
查看>>
Tensorflow minist-softmax
查看>>
Kotlin中的also、let、run、with、apply函数的用法
查看>>
常用 Markdown 语法汇总
查看>>
12、Flutter Widget - InheritedModel;
查看>>
VR全景创业:这些创业条件你具备了吗?
查看>>
WEB前端学习如何分清主次和优先级?
查看>>