搜索
首页数据库Oracleoracle怎么截取字符串中的一部分字符

oracle怎么截取字符串中的一部分字符

Feb 14, 2022 pm 12:47 PM
oracle截取字符串

在oracle中,可以利用Instr()和substr()函数来截取字符串中的一部分字符,语法为“SUBSTR('需要截取的字符串',截取开始位置, INSTR('需要截取的字符串,'','查找开始位置','第几次出现')-1) ”。

oracle怎么截取字符串中的一部分字符

本教程操作环境:Windows7系统、Oracle 11g版、Dell G3电脑。

oracle截取字段中的部分字符串

使用Oracle中Instr()和substr()函数

在Oracle中可以使用instr函数对某个字符串进行判断,判断其是否含有指定的字符。

其语法为:

instr(sourceString,destString,start,appearPosition).   
instr('源字符串' , '目标字符串' ,'开始位置','第几次出现')

其中

  • sourceString代表源字符串;

  • destString代表想聪源字符串中查找的子串;

  • start代表查找的开始位置,该参数可选的,默认为1;

  • appearPosition代表想从源字符中查找出第几次出现的destString,该参数也是可选的,默认为1;

如果start的值为负数,那么代表从右往左进行查找,但是位置数据仍然从左向右计算。

返回值为:查找到的字符串的位置。

对于instr函数,我们经常这样使用:从一个字符串中查找指定子串的位置。例如:

SQL> select instr('yuechaotianyuechao','ao') position from dual;
 POSITION
 ----------
 6

从第7个字符开始搜索

SQL> select instr('yuechaotianyuechao','ao', 7) position from dual;
 POSITION
 ----------
 17

从第1个字符开始,搜索第2次出现子串的位置

SQL> select instr('yuechaotianyuechao','ao', 1, 2) position from dual;
 POSITION
 ----------
 17

对于instr函数,我们经常这样使用:从一个字符串中查找指定子串的位置。例如: 

SQL> select instr('abcdefgh','de') position from dual; 
POSITION 
---------- 
4

从1开始算 d排第四所以返回4 

SQL>select instr('abcdefghbc','bc',3) position from dual; 
POSITION 
---------- 
9

从第3个字符开始算起 第3个字符是c,所以从3开始以后的字符串找查找bc,返回9 

substr函数的用法,取得字符串中指定起始位置和长度的字符串  ,默认是从起始位置到结束的子串。

 substr( string, start_position, [ length ] )       substr('目标字符串',开始位置,长度)

如: 

      substr('This is a test', 6, 2)     would return 'is' 
      substr('This is a test', 6)     would return 'is a test' 
      substr('TechOnTheNet', -3, 3)     would return 'Net' 
      substr('TechOnTheNet', -6, 3)     would return 'The'select substr('Thisisatest', -4, 2) value from dual

SUBSTR()函数   

1.用处:是从给定的字符表达式或备注字段中返回一个子字符串。    

2.语法格式:

substr(string string, int a, int b);
substr(string string, int a) ; 

格式1:

        1、string 需要截取的字符串 

        2、a 截取字符串的开始位置(注:当a等于0或1时,都是从第一位开始截取)

        3、b 要截取的字符串的长度

    格式2:

        1、string 需要截取的字符串

        2、a 可以理解为从第a个字符开始截取后面所有的字符串。

oracle截取字符串

将 C3411.907w15 截取点号之前的字符串 C3411    SUBSTR ('C3411.907w15',  0,  INSTR ('C3411.907w15, '.', 1, 1) - 1)  

SELECT SUBSTR ('C3411.907w15', 0, INSTR ('C3411.907w15, '.', 1, 1) - 1)
  FROM DUAL

将 C3411.907w15 截取点号之后 的字符串 907w15   SUBSTR ('C3411.907w15', INSTR ('C3411.907w15', '.', 1, 1)+1)

SELECT SUBSTR ('C3411.907w15', INSTR ('C3411.907w15', '.', 1, 1)+1)
  FROM DUAL

项目应用实例:

原始字符串:

原始字段中存在7个“_”,我现在只想取出最后一个“_”后面的字符串,该怎么解决呢?

分两步:

第一步,通过Instr()函数,找到第7个“_”字符:

select instr('Q房网集团_经纪事业部_华南区_深圳世华_营业部_南山前海区_前海中心片区_前海五分店','_', 1, 7) fdisplayname from SHENZHENJM1222.B

或者:

select instr('Q房网集团_经纪事业部_华南区_深圳世华_营业部_南山前海区_前海中心片区_前海五分店', '_', -1, 1) fdisplayname FROM SHENZHENJM1222.B

两者效果一样,下面的-1,表示从右边开始算起始字符,1表示获取第一个“_”

获取到的结果如图:

 

第2步,通过substr()函数,取出所需要的字段:

select substr(fdisplayname,instr(fdisplayname,'_',-1,1)+1) fdisplayname from SHENZHENJM1222.B

fdisplayname:代表字段名,相当于元字符串

重点介绍一下+1

+1表示在目标字符串“_”后的第一个字符串开始截取

下面看一下不同的数字的情况:

 

select substr(fdisplayname,instr(fdisplayname,'_',-1,1)+1) fdisplayname from SHENZHENJM1222.B

在来看一下instr(fdisplayname,'_',-1,1)中的1是啥意思:

推荐教程:《Oracle教程

以上是oracle怎么截取字符串中的一部分字符的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
Oracle的软件套件:解释的产品和服务Oracle的软件套件:解释的产品和服务May 09, 2025 am 12:12 AM

Oracle的软件套件包括数据库管理、ERP、CRM等,帮助企业优化运营、提高效率、降低成本。1.OracleDatabase管理数据,2.OracleERPCloud处理财务、人力资源和供应链,3.使用OracleSCMCloud优化供应链管理,4.通过API和集成工具确保数据流动和一致性。

MySQL与Oracle:许可,功能和福利MySQL与Oracle:许可,功能和福利May 08, 2025 am 12:05 AM

MySQL和Oracle的主要区别在于许可证、功能和优势。1.许可证:MySQL提供GPL许可证,免费使用,Oracle采用专有许可证,价格昂贵。2.功能:MySQL功能简单,适合Web应用和中小型企业,Oracle功能强大,适合大规模数据和复杂业务。3.优势:MySQL开源免费,适合初创公司,Oracle性能可靠,适合大型企业。

MySQL与Oracle:选择右数据库系统MySQL与Oracle:选择右数据库系统May 07, 2025 am 12:09 AM

MySQL和Oracle在性能、成本和使用场景上有显着差异。 1)性能:Oracle在复杂查询和高并发环境下表现更好。 2)成本:MySQL开源,成本低,适合中小型项目;Oracle商业化,成本高,适用于大型企业。 3)使用场景:MySQL适用于Web应用和中小型企业,Oracle适合复杂的企业级应用。选择时需根据具体需求权衡。

Oracle软件:最大化效率和性能Oracle软件:最大化效率和性能May 06, 2025 am 12:07 AM

Oracle软件可以通过多种方法提升性能。1)优化SQL查询,减少数据传输量;2)适当管理索引,平衡查询速度和维护成本;3)合理配置内存,优化SGA和PGA;4)减少I/O操作,使用合适的存储设备。

甲骨文:企业软件和云计算甲骨文:企业软件和云计算May 05, 2025 am 12:01 AM

Oracle在企业软件和云计算领域如此重要是因为其全面的解决方案和强大的技术支持。1)Oracle提供从数据库管理到ERP的广泛产品线,2)其云计算服务如OracleCloudPlatform和Infrastructure帮助企业实现数字化转型,3)Oracle数据库的稳定性和性能以及云服务的无缝集成提升了企业效率。

MySQL与Oracle:数据库系统的比较分析MySQL与Oracle:数据库系统的比较分析May 04, 2025 am 12:13 AM

MySQL和Oracle各有优劣,选择时需综合考虑:1.MySQL适合轻量级、易用需求,适用于Web应用和中小型企业;2.Oracle适合功能强大、可靠性高需求,适用于大型企业和复杂业务系统。

MySQL与Oracle:了解许可和成本MySQL与Oracle:了解许可和成本May 03, 2025 am 12:19 AM

MySQL采用GPL和商业许可,适合小型和开源项目;Oracle采用商业许可,适合需要高性能的企业。MySQL的GPL许可免费,商业许可需付费;Oracle许可费用按处理器或用户计算,成本较高。

甲骨文:从数据库到云服务甲骨文:从数据库到云服务May 02, 2025 am 12:05 AM

Oracle从数据库到云服务的演变历程表明其技术实力和市场洞察力强大。1.Oracle起源于上世纪70年代,以关系数据库管理系统闻名,推出了PL/SQL等创新功能。2.Oracle数据库核心是关系模型和SQL优化,支持多租户架构。3.Oracle云服务通过OCI提供IaaS、PaaS和SaaS,AutonomousDatabase表现出色。4.使用Oracle时需注意许可模式复杂、性能优化和云迁移中的数据安全问题。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。