本篇文章小编给大家分享一下Oracle中decode函数用法代码,文章代码介绍的很详细,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看。
1.decode函数的两种形式
第一种形式
含义解释:
decode(条件,值1,返回值1,值2,返回值2,…值n,返回值n,缺省值)
该函数的含义如下:
IF 条件=值1 THEN RETURN(翻译值1) ELSIF 条件=值2 THEN RETURN(翻译值2) ...... ELSIF 条件=值n THEN RETURN(翻译值n) ELSE RETURN(缺省值) END IF
第二种形式
decode(字段或字段的运算,值1,值2,值3)
这个函数运行的结果是,当字段或字段的运算的值等于值1时,该函数返回值2,否则返回值3
当然值1,值2,值3也可以是表达式,这个函数使得某些sql语句简单了许多
sign()函数
解释:
sign()函数根据某个值是0、正数还是负数,分别返回0、1、-1
用法示例:
select id,sign(id-2) from t_decode;
截图效果:
lpad()函数
在字段id前边补字段0 长度为2
select lpad(id,2,0) from t_decode;
2.decode的一些工作常用思路总结
a.准备测试数据
创建测试表t_decode,并插入测试数据
//创建表,插入数据,查询 create table t_decode( id integer, name varchar2(10) ); //插入数据 insert into t_decode values (1,'a'); insert into t_decode values (2,'b'); insert into t_decode values (3,'c'); insert into t_decode values (4,'a');
数据样式
b.第一种形式decode函数的常用思路
1. 简单使用:判断字符串
select id,name, decode(id,1,'第一个',2,'第二个',3,'第三个','没有') new_id from t_decode;
2.使用decode函数分段
判断表中id大小并根据大小划分不同范围
(-,2) low
[2,4) mid
[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;
忍者必须死34399账号登录版 最新版v1.0.138v2.0.72
下载勇者秘境oppo版 安卓版v1.0.5
下载忍者必须死3一加版 最新版v1.0.138v2.0.72
下载绝世仙王官方正版 最新安卓版v1.0.49
下载Goat Simulator 3手机版 安卓版v1.0.8.2
Goat Simulator 3手机版是一个非常有趣的模拟游
Goat Simulator 3国际服 安卓版v1.0.8.2
Goat Simulator 3国际版是一个非常有趣的山羊模
烟花燃放模拟器中文版 2025最新版v1.0
烟花燃放模拟器是款仿真的烟花绽放模拟器类型单机小游戏,全方位
我的世界动漫世界 手机版v友y整合
我的世界动漫世界模组整合包是一款加入了动漫元素的素材整合包,
我的世界贝爷生存整合包 最新版v隔壁老王
我的世界MITE贝爷生存整合包是一款根据原版MC制作的魔改整