Oracle函数decode的用法简介
以下的文章主要是介绍Oracle 函数decode,我们都知道decode函数将该数值和c一系列的相关序偶相比较来决定最终的相关的返回结果 。所谓的序偶,简单的说就是成对的出现;我们将这个函数与switch比较。

10年专注建站、设计、互联网产品按需开发服务,业务涵盖成都品牌网站建设、成都商城网站开发、微信小程序定制开发、软件系统开发、重庆APP开发等。凭借多年丰富的经验,我们会仔细了解每个客户的需求而做出多方面的分析、设计、整合,为客户设计出具风格及创意性的商业解决方案,成都创新互联更提供一系列网站制作和网站推广的服务,以推动各中小企业全面信息数字化,并利用创新技术帮助各行业提升企业形象和运营效率。
我们发现他们基本相似,***不同的是switch将要比较的值放在case后面都加上了break中。
以下一个例子:(我直接从网上找的)
- SELECT id,
- decode(flag,’Y’,'Yes’,'N’,’No’,NULL,’None’,'Yes’)
- FROM t_test;
当t_test的flag字段为Y时返回Yes,为N时返回No,为NULL时返回None,默认返回Yes。
看看我遇到的问题:
- SELECT a.id,
- a.user_name,
- a.oper_time time2,
- a.oper_type,
- a.description,
- a.oper_flag,
- decode(a.oper_flag, '1', '成功', '失败') oper_flag,
- a.ip,
- b.true_name
- FROM SEC_LOG_OPERATION a
- left join sec_user b on a.user_name = b.user_name
- where 11 = 1
- order by oper_time desc
原来这红线部分是:
Oracle 函数decode(a.oper_flag, 1, '成功', '失败')
我在查询的时候会报错,原因是oper_flag这个字段数据中有非数字类型,也就是这个字段不仅有1、0,还有“失败”,这样数据!=字符。所以我们把1当字符处理就可以了。
【编辑推荐】
- Oracle join的正确用法描述
- Oracle ebs的oaf开发环境进行正确的配置
- Oracle reports功不可没,实现报表定长输出
- 查看Oracle当前连接数的具体方案
- 加速Oracle大批量数据处理的2个好用方案
文章题目:Oracle函数decode的用法简介
新闻来源:http://www.jxjierui.cn/article/dhcchpp.html


咨询
建站咨询
