我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Oracle中decode函数用法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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;

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

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Oracle中decode函数用法

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

下载Word文档

猜你喜欢

oracle中decode函数的用法是什么

在Oracle中,DECODE函数用于根据给定的条件对一个表达式进行检查并返回结果。它的基本语法如下:DECODE(expr, search1, result1, search2, result2, …, default_result)
oracle中decode函数的用法是什么
2024-04-09

Oracle中decode函数用法是怎样的

这期内容当中小编将会给大家带来有关Oracle中decode函数用法是怎样的,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1.decode函数的两种形式第一种形式含义解释:decode(条件,值1,返回值
2023-06-22

Oracle中decode函数详解

Oracle中的decode函数是一个条件表达式函数,用于根据给定的条件对一个或多个表达式进行比较,并返回与匹配条件相对应的结果表达式。语法:DECODE(expr, search1, result1, search2, result2,
2023-09-09

Oracle中decode函数怎么使用

小编给大家分享一下Oracle中decode函数怎么使用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!DECODE含义decode(条件,值1,返回值1,值2,返
2023-06-22

mysql中decode函数的用法

decode 函数根据给定条件映射值:评估表达式并与条件值匹配。如果匹配,返回对应结果值;如果不匹配,返回默认值。MySQL 中 DECODE 函数的用法DECODE 函数是一个非常有用的函数,它允许您根据给定的条件将一个值映射到另一个值
mysql中decode函数的用法
2024-05-01

oracle的decode函数用法是什么

oracle的decode函数用法是:1、基本用法,根据一个条件字段进行简单的条件判断;2、多条件判断,根据多个条件进行不同的结果返回;3、嵌套DECODE函数,将DECODE函数嵌套使用以实现更复杂的条件判断和结果返回;4、与其他SQL语
2023-10-22

Oracle中DECODE函数的基本用法解析

Oracle中DECODE函数的基本用法解析在Oracle数据库中,DECODE函数是一种非常常用的函数,用于实现类似于多层if-else语句的逻辑判断和数值替换。DECODE函数的基本语法如下:DECODE(expr, search1,
Oracle中DECODE函数的基本用法解析
2024-03-07

oracle decode函数怎么用

oracle decode 函数是一个条件语句,用于根据指定条件返回不同的值。语法为 decode(expression, value1, result1, ..., default_result),其中 expression 是要评估的表
oracle decode函数怎么用
2024-05-21

Oracle之DECODE函数的用法是什么

Oracle的DECODE函数用于对一个表达式进行条件判断,根据条件的不同返回不同的结果。它的基本语法如下:DECODE(expr, search1, result1[, search2, result2, ..., default])其中
2023-10-12

oracle中decode函数的使用方法是什么

在Oracle数据库中,DECODE函数用于根据指定的条件对值进行比较,如果满足条件则返回一个值,否则返回另一个值。DECODE函数的使用方法如下:DECODE(expression, search_value1, return_valu
oracle中decode函数的使用方法是什么
2024-03-15

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录