广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >Oracle中decode函数用法
  • 169
分享到

Oracle中decode函数用法

Oracledecode函数用法decode函数用法 2022-11-12 21:11:42 169人浏览 泡泡鱼
摘要

1.decode函数的两种形式 第一种形式 含义解释: decode(条件,值1,返回值1,值2,返回值2,…值n,返回值n,缺省值) 该函数的含义如下: IF 条件=值1 TH

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;

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

--结束END--

本文标题: Oracle中decode函数用法

本文链接: https://www.lsjlt.com/news/160186.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Oracle中decode函数用法
    1.decode函数的两种形式 第一种形式 含义解释: decode(条件,值1,返回值1,值2,返回值2,…值n,返回值n,缺省值) 该函数的含义如下: IF 条件=值1 TH...
    99+
    2022-11-12
    Oracle decode函数用法 decode函数用法
  • oracle decode函数的用法
    oracle decode函数,不管查询的结果是否满足‘PRIMARY’,参数中的select语句还是会执行的,通过查看执行计划就知道 set autotrace traceonly select...
    99+
    2022-10-18
    ja 函数 用法
  • oracle中decode函数的使用方法
    本篇文章给大家分享的是有关oracle中decode函数的使用方法,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。decode的几种用法1:使用...
    99+
    2022-10-18
    oracle decode 使用
  • Oracle中decode函数用法是怎样的
    这期内容当中小编将会给大家带来有关Oracle中decode函数用法是怎样的,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1.decode函数的两种形式第一种形式含义解释:decode(条件,值1,返回值...
    99+
    2023-06-22
  • Oracle中decode函数怎么用
    小编给大家分享一下Oracle中decode函数怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!含义解释: decode(条...
    99+
    2022-10-18
    oracle decode
  • Oracle中decode函数详解
    Oracle中的decode函数是一个条件表达式函数,用于根据给定的条件对一个或多个表达式进行比较,并返回与匹配条件相对应的结果表达...
    99+
    2023-09-09
    oracle
  • oracle的decode函数用法是什么
    oracle的decode函数用法是:1、基本用法,根据一个条件字段进行简单的条件判断;2、多条件判断,根据多个条件进行不同的结果返回;3、嵌套DECODE函数,将DECODE函数嵌套使用以实现更复杂的条件判断和结果返回;4、与其他SQL语...
    99+
    2023-10-22
    oracle
  • Oracle Decode函数的使用
    DECODE函数的可以根据用户给定的判定条件给定想要的结果语法:DECODE(expr,{search,result,}….,default) 这里给的search,result可以是多个,而括号里所有元素...
    99+
    2022-10-18
    oracle 函数 decode
  • oracle中如何使用decode函数
    今天就跟大家聊聊有关oracle中如何使用decode函数,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。  一、DECODE函数是ORACLE PL...
    99+
    2022-10-18
    oracle decode
  • Oracle中decode函数如何使用
    这篇文章将为大家详细讲解有关Oracle中decode函数如何使用,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。函数介绍:DECODE函数是ORACLE P...
    99+
    2022-10-18
    oracle decode
  • Oracle中decode函数怎么使用
    小编给大家分享一下Oracle中decode函数怎么使用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!DECODE含义decode(条件,值1,返回值1,值2,返...
    99+
    2023-06-22
  • oracle decode函数和 sign函数
    流程控制函数 DECODEdecode()函数简介:主要作用:将查询结果翻译成其他值(即以其他形式表现出来,以下举例说明);使用方法:Select decode(columnname,值1,翻译值...
    99+
    2022-10-18
    oracle %d ig
  • Oracle之DECODE函数的用法是什么
    Oracle的DECODE函数用于对一个表达式进行条件判断,根据条件的不同返回不同的结果。它的基本语法如下:DECODE(expr,...
    99+
    2023-10-12
    Oracle
  • 怎么在oracle中使用decode函数
    今天就跟大家聊聊有关怎么在oracle中使用decode函数,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1:使用decode判断字符串是否一样DE...
    99+
    2022-10-18
    oracle decode
  • decode函数怎么在Oracle中使用
    decode函数怎么在Oracle中使用?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。含义解释: decode(条件,值1,返回值1,值2...
    99+
    2022-10-18
    oracle decode
  • oracle的decode函数怎么使用
    Oracle的DECODE函数用于根据给定的条件对一个表达式进行解码。它的基本语法如下:DECODE(expression, sea...
    99+
    2023-08-29
    oracle decode
  • Oracle进阶DECODE函数使用详解
    DECODE含义 decode(条件,值1,返回值1,值2,返回值2,…值n,返回值n,缺省值) 这个是decode的表达式,具体的含义解释为: IF 条件=值1 THEN   ...
    99+
    2022-11-12
    Oracle DECODE函数使用 Oracle DECODE函数
  • decode函数的用法是什么
    decode函数是Python中的一个字符串方法,用于将字符串从指定的编码方式解码为Unicode字符串。它的用法是:decode(...
    99+
    2023-09-14
    decode
  • Python中decode函数怎么用
    在Python中使用decode函数的方法decode:decode()函数的作用是指定的编码格式解码字符串。decode()函数语法:str.decode(encoding='UTF-8',errors='strict')参数:encod...
    99+
    2022-10-05
    python
  • Oracle nvl、nvl2、nullif、decode、case函数详解
    1、NVL函数    nvl(expr1,expr2),如果expr1为空,则返回expr2;2、NVL2函数    nvl2...
    99+
    2022-10-18
    oracle 空值判断函数 nullif
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作