oracle中decode函数的使用

article/2025/10/12 19:56:40

一、DECODE函数相当于if条件语句,它将输入的值与函数中的参数列比较,根据输入值返回一个对应值

 1、语法:decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值) 
 2、说明:当“条件”等于“值1”的时候,显示“返回值1”,等于“值2”的时候,显示“返回值2”,依次类推,如果都不满足,则显示“缺省值”即默认值
 3、逻辑:类似于以下操作

if(条件=值1){返回值1
}else if(条件=值2){返回值2
} ......
else{缺省值/默认值
}

 4、举例

  (1)先了解数据表结构:id是数据id,login_name是账号,为方便演示,此处做了查询条件的限制

  (2)执行操作后的结果:当login_name的值是“test”的时候,输出“我是第一个”,当login_name的值是“mtest”的时候,输出“我是就是我”,当前面的情况都不满足时,输出“哈哈”

  (3)需要注意的是,当decode函数中只有4个值的时候【decode(条件,值,返回值1,返回值2)】,就要考虑只是做了一种判断,即条件满足值时输出返回值1,否则输出返回值2

   PS:图中涉及到的SQL,可复制后自行修改

select id,login_name AS "账号" FROM SYS_USER where login_name like '%test%'select id,login_name AS "账号",DECODE(login_name,'test','我是第一个','mtest','我是就是我','哈哈') AS "输出内容"   FROM SYS_USER  where  login_name like '%test%'select id,login_name AS "账号",DECODE(login_name,'test','我是第一个','哈哈') AS "输出内容"   FROM SYS_USER  where  login_name like '%test%'

二、与sign()函数结合使用

  1、sign是一种计算机函数,语法为sign(值),当值大于0时返回1,小于0时返回-1,等于0时返回0
  2、举例:id为数据的id,此处仅做参考作用,NO为编号


  3、结合使用

  (1)可以用来标记数据

 

 (2)同样可以用来做分段函数,如当薪资大于等于5000的时候,分段为“高薪”;当薪资大于等于3000且小于5000时属于“中薪”;小于3000属于低

   逻辑: 薪资与5千比较,返回-1表明小于5000,即往下执行-1对应的操作,反之大于等于5千,表示高薪;薪资与3000比较,返回-1则表示小于3000,即低薪,反之大于等于3千且小于5千属于中薪

   示例:

  说明: Ⅰ、sign(500-5000),返回-1,执行-1对应的操作,即decode(sign(500-3000)  , 1,'中薪',0,'中薪',- 1,'低薪'),sign(500-3000)返回-1,即返回值为“低薪”

             Ⅱ、sign(6000-5000),返回1,即返回值为“高薪”

             Ⅲ 、sign(3500-5000),返回-1,执行-1对应的操作,即decode(sign(3500-3000)  , 1,'中薪',0,'中薪',- 1,'低薪'),sign(3500-3000)返回1,即返回值为“中薪”

             Ⅳ、sign(3200-5000),返回-1,执行-1对应的操作,即decode(sign(3200-3000)  , 1,'中薪',0,'中薪',- 1,'低薪'),sign(3200-3000)返回1,即返回值为“中薪”

            Ⅴ、sign(6000-5000),返回1,即返回值为“高薪”

            Ⅵ、sign(4500-5000),返回-1,执行-1对应的操作,即decode(sign(4500-3000)  , 1,'中薪',0,'中薪',- 1,'低薪'),sign(4500-3000)返回1,即返回值为“中薪”

  PS:图中涉及到的SQL,可复制后自行修改


select id,NO AS "编号",sign(NO) AS "编号的返回值" FROM SYS_USER  where login_name like '%test%'select id,NO AS "编号",sign(NO) AS "编号的返回值",decode(sign(NO),-1,'编号为负数','0','编号为自然数0','编号是正数') AS "输出结果" FROM SYS_USER  where login_name like '%test%'SELECTID,NO AS "薪资",DECODE (SIGN (NO - 5000),1,'高薪',0,'高薪' ,- 1,DECODE (SIGN (NO - 3000), 1,'中薪',0,'中薪',- 1,'低薪'))
FROMSYS_USER
WHERElogin_name LIKE '%test%'

 三、结合SUM()函数实现表或者视图中的列转行

 需求:以账号为表头,显示对应的薪资数据

 1、先看原数据:

  2、利用decode函数实现根据账户名显示对应的薪资数据

  3、利用sum求和函数,实现最终需求

 关于第二步中的根据一条数据中的某一列显示该数据中的另一列数据,这个应该是decode算法的原因,具体没深研究,感兴趣的小伙伴儿可以自己研究

PS:图中涉及到的SQL,可复制后自行修改

select login_name AS "账号",NO AS "薪资"  FROM SYS_USER  where  login_name like 'test%'SELECTDECODE (login_name, 'test', NO, 0) TEST,DECODE (login_name, 'test01', NO, 0) test01,DECODE (login_name, 'test1', NO, 0) test1,DECODE (login_name, 'test123456789',NO,0) test123456789,DECODE (login_name, 'testing', NO, 0) testing
FROMSYS_USER
WHERElogin_name LIKE 'test%'SELECTSUM (DECODE (login_name, 'test', NO, 0)) TEST,SUM (DECODE (login_name, 'test01', NO, 0)) test01,SUM (DECODE (login_name, 'test1', NO, 0)) test1,SUM (DECODE (login_name,'test123456789',NO,0)) test123456789,SUM (DECODE (login_name, 'testing', NO, 0)) testing
FROMSYS_USER
WHERElogin_name LIKE 'test%'SELECTDECODE (login_name, 'test', NAME, 0) TEST,DECODE (login_name, 'test01',NAME, 0) test01,DECODE (login_name, 'test1', NAME, 0) test1,DECODE (login_name, 'test123456789',NAME,0) test123456789,DECODE (login_name, 'testing', NAME, 0) testing
FROMSYS_USER
WHERElogin_name LIKE 'test%'

四、结合instr()函数,实现字符的搜索并返回结果

   1、先来了解下instr()函数:instr函数为字符查找函数,其功能是查找一个字符串在另一个字符串中首次出现的位置


   (1)语法:instr( string1, string2, start_position,nth_appearance )
                     string1:源字符串,要在此字符串中查找。
                     string2:要在string1中查找的字符串 。
                     start_position:代表string1 的哪个位置开始查找,此参数可选,如果省略默认为1. 字符串索引从1开始。如果此参数为正,从左到右开始检索,如果此参数为负,从右到左检索,返回要查找的字符串在源字符串中的开始索引。
                     nth_appearance:代表要查找第几次出现的string2.,此参数可选,如果省略,默认为 1。如果为负数系统会报

   注意:位置索引号从1开始。如果String2在String1中没有找到,instr函数返回0

(2)示例:

SELECT instr('syranmo','s') FROM dual; -- 返回 1
SELECT instr('syranmo','ra') FROM dual; -- 返回 3
SELECT instr('syran mo','at',1,2) FROM dual; -- 返回 0
select instr('helloworld','l') from dual; --返回结果:3    默认第一次出现“l”的位置
select instr('helloworld','lo') from dual; --返回结果:4   即:在“lo”中,“l”开始出现的位置
select instr('helloworld','wo') from dual; --返回结果:6   即“w”开始出现的位置

 2、结合instr函数,实现需求

 PS:图中涉及到的SQL,可复制后自行修改

SELECT login_name AS "账户",INSTR(login_name, 'test') AS "返回值",DECODE(INSTR(login_name, 'test'),0,'不含有test','含有test') AS "查询结果"  FROM SYS_USER  

http://chatgpt.dhexx.cn/article/oH3XGl7r.shtml

相关文章

Oracle函数之DECODE函数

1.语法 2.用途 DECODE 函数将 expr 与 search 的值逐个比较。如果 expr 与 search 值相等,Oracle 返回 search 相应的 result。如果 expr 与 search 值都不匹配,Oracle 返回 default,如果没有函数中没有赋值 default,Oracle 返回…

java decode函数用法_decode函数的几种用法

1:使用decode判断字符串是否一样 DECODE(value,if1,then1,if2,then2,if3,then3,...,else) 含义为 IF 条件=值1 THEN RETURN(value 1) ELSIF 条件=值2 THEN RETURN(value 2) ...... ELSIF 条件=值n THEN RETURN(value 3) ELSE RETURN(default) END IF select empno, decode(empn…

Oracle decode函数

一 两种语法格式 1 decode(expression,value,result1,result2) 如果expressionvalue,则输出result1,否则输出result2 例子: (123,输出a) (12≠4,输出b) 2 decode(expre…

decode()函数简介

2019独角兽企业重金招聘Python工程师标准>>> decode()函数简介:主要作用:将查询结果翻译成其他值(即以其他形式表现出来,以下举例说明);使用方法:Select decode(columnna…

冯诺依曼元胞计算机,冯诺依曼元胞自动机

冯诺依曼元胞自动机(John V on Neumann’s Cellular Automaton) 冯诺依曼元胞自动机是由计算机科学家约翰冯诺依曼发明的一种图灵完备的元胞自动机。目前它还有三种不同的规则,分别名叫:JvN29,Nobili32,Hutton32.可以模拟许多“机器”&#x…

元胞自动机学习笔记

元胞自动机学习笔记 2021.7.19 一、简介: 元胞自动机(cellular automata,CA):是一种时间,空间,状态都离散,空间相互作用和时间因果关系为局部的网格动力学模型,具有模拟复杂系统时空演化过程的能力。 二…

python实现元胞自动机

这是刚学习写代码时完成的,因此很多地方编写的可能不太美观,但运行起来没有问题,先发出来,之后有精力了在修改美化。 该元胞自动机的功能: 1.初始化按一定概率在各个位置生成元胞。 2.迭代,每次迭代元胞…

元胞自动机基本概念

目录 前言 一、元胞自动机的概述 二、元胞自动机的构成 1.元胞 2.元胞空间 3.元胞邻居 4.元胞规则 总结 前言 元胞自动机的寒假学习笔记,这里只是一些基本的概念,后面一篇文章会详细、具体地去介绍基于MATLAB元胞自动机的代码实现。&#xff08…

元胞自动机简单理解

元胞自动机 元胞自动机( Cellular Automata) 是 20 世纪 50 年代初由计算机之父冯诺依曼为了模拟生命系统所具有的自复制功能而提出来的网格动力学模型。 概念 元胞自动机采用离散的空间布局和离散的时间间隔,将元胞分成有限种状态&#x…

matlab元胞自动机入门详解

元胞自动机的初步理解 对元胞自动机的初步认识 元胞自动机(CA)是一种用来仿真局部规则和局部联系的方法。典型的元 胞自动机是定义在网格上的,每一个点上的网格代表一个元胞与一种有限的状 态。变化规则适用于每一个元胞并且同时进行。元胞的…

元胞自动机-附代码注释

元胞自动机(Cellular Automata CA)是一种时空离散的局部动力学模型,是研究复杂系统的一种典型方法,适用于空间复杂系统的时空动态模拟研究。 元胞自动机不是由严格定义的物理方程或函数确定,而是用一系列模型构造的规则…

元胞自动机简介

摘要: 元胞自动机能利用简单的局部规则和离散方法描述复杂的全局的连续系统,已成为探索复杂系统的一种有效工具。文章 阐述了元胞自动机的发展历程、结构、特征及基本理论与方珐;介绍了元胞自动机在寡头垄断行为、交通管理及工程运输、城市…

数模笔记14-元胞自动机

元胞自动机模型 元胞自动机理论 元胞自动机(Cellular Automata,CA)是一种时空离散的局部动力学模型,是研究复杂系统的一种典型方法,特别适合用于空间复杂系统的时空动态模拟研究。 元胞自动机不是由严格定义的物理方程…

【数学建模】元胞自动机

前些天发现一个通俗易懂,风趣幽默的人工智能学习网站: 传送门 A 简介 1 历史 最初的元胞自动机是由冯 诺依曼在 1950 年代为模拟生物 细胞的自我复制而提出的. 但是并未受到学术界重视. 1970 年, 剑桥大学的约翰 何顿 康威设计了一个电脑游戏 “生…

关于元胞自动机

元胞自动机(cellular automata,CA) 是一种时间、空间、状态都离散,空间相互作用和时间因果关系为局部的网格动力学模型,具有模拟复杂系统时空演化过程的能力。 其实在去年暑假准备国赛的时候试图过自学,但受限于,网上…

元胞自动机(数学建模)

一.元胞自动机的概念 元胞自动机(cellular automata,CA) 是一种时间、空间、状态都离散,空间相互作用和时间因果关系为局部的网格动力学模型,具有模拟复杂系统时空演化过程的能力。 元胞自动机是用一系列模型构造的规则构成,只要满…

元胞自动机

一个一个的格子看做是一个个的元胞,他们按照自己的规则自动进行状态改变就是元胞自动机。 定义:是一种时间、空间、状态都离散,空间相互作用和时间因果关系为局部的网格动力学模型,具有模拟复杂系统时空演化过程的能力。 元胞自…

元胞自动机简介(美赛复习一)

为美赛准备,进行元胞自动机的简单回顾。 本文只是简单回顾,可能会进行相关论文复现。 文章目录 一、简介 1.元胞2.元胞空间3.元胞邻居4.边界条件5.规则二、简单例子 一、简介 元胞自动机:是一种时间、空间、状态都离散,空间相互…

【数学建模】元胞自动机(CA)详解 + Matlab代码实现

文章目录 一、什么是元胞自动机?二、图解元胞自动机:三、案例Matlab代码实现:1.奇偶规则2.生命游戏3.森林火灾 一、什么是元胞自动机? 元胞自动机(cellular automata,CA) 是一种时间、空间、状态都离散,空…

迁移学习在金融行业的应用探索

摘要:通过迁移学习技术,解决少量数据(较少重叠样本和特征)和个性化(较少标记)的问题,从数据丰富的领域迁移到数据匮乏的领域。通过迁移学习在保证模型准确率的同时,也提高了建造模型…