Oracle中decode函数用法


当前第2页 返回上一页

[4,-] high

select id,name,
   decode(sign(id - 4),1,'high id',0,'high id','-1',
                          decode(sign(id - 2),1,'mid id',0,'mid id',-1,'low id'))
from t_decode; 

c.第二种形式decode函数的常用思路

1. 比较大小

-- 比较大小
select decode(sign(100-90),-1,100,90) from dual;

2. 使用表达式来搜索字符串

判断name中是否含有a?

select id,name,decode(instr(name,'a'),0,'不含有a','含有a') as info from t_decode;

3. 实现行列转换

注意:decode相当于:case when then else end语句

select 
	sum(decode(name,'a',id,0)) id_1,
	sum(decode(name,'b',id,0)) id_2,
	sum(decode(name,'c',id,0)) id_3 from t_decode;

添加测试:

select 
   decode(name,'a',id,0) id_1,
   decode(name,'b',id,0) id_2,
   decode(name,'c',id,0) id_3 
from t_decode;

-- 相等于:case when then else end
select 
	case name when 'a' then id else 0 end as id_1,
    case name when 'b' then id else 0 end as id_2,
    case name when 'c' then id else 0 end as id_3 
from t_decode;

4. 结合Lpad函数,如何使主键的值自动加1并在前面补0

结合Lpad函数,如何使主键的值自动加1并在前面补0
select lpad(decode(count(id),0,1,max(to_number(id)+1)),14,'0') new_id from t_decode;

拆分详细讲解:

select * from t_decode

select lpad(id,2,0) from t_decode

select to_number(id) from t_decode;

select max(to_number(id)+1) from t_decode;

select decode(count(id),0,1,max(to_number(id)+1)) from t_decode;

select lpad(decode(count(id),0,1,max(to_number(id)+1)),14,‘0') new_id from t_decode;

以上所述是小编给大家介绍的Oracle中decode函数用法,希望对大家有所帮助。在此也非常感谢大家对网站的支持!


标签:Oracle

返回前面的内容

相关阅读 >>

oracle读取excel数据

分享oracle 11g client 客户端安装步骤(图文详解)

orcale中的to_number方法使用

oracle sid存在解決方法

oracle 12c实现手工建库而非cdb及cdb创建的方法

oracle数据库安全策略分析(一)

oracle分析函数用法详解

oracle导入数据库报错怎么办?

windows server 2012 安装oracle11g(图文教程)

redhat6.5安装oracle11g的方法

更多相关阅读请进入《oracle》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...