Oracle截取字符串和查找字符串,联合使用截取特定字符

Posted 小菜77

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Oracle截取字符串和查找字符串,联合使用截取特定字符相关的知识,希望对你有一定的参考价值。

oracle 截取字符(substr),检索字符位置(instr) case when then else end语句使用 收藏 
常用函数:substr和instr
1.SUBSTR(string,start_position,[length])    求子字符串,返回字符串
解释:string 元字符串
       start_position   开始位置(从0开始)
       length 可选项,子字符串的个数
For example:
substr("ABCDEFG", 0); //返回:ABCDEFG,截取所有字符 
substr("ABCDEFG", 2); //返回:CDEFG,截取从C开始之后所有字符 
substr("ABCDEFG", 0, 3); //返回:ABC,截取从A开始3个字符 
substr("ABCDEFG", 0, 100); //返回:ABCDEFG,100虽然超出预处理的字符串最长度,但不会影响返回结果,系统按预处理字符串最大数量返回。 
substr("ABCDEFG", -3); //返回:EFG,注意参数-3,为负值时表示从尾部开始算起,字符串排列位置不变。

2.INSTR(string,subString,position,ocurrence)查找字符串位置
解释:string:源字符串
      subString:要查找的子字符串
      position:查找的开始位置
      ocurrence:源字符串中第几次出现的子字符串
For example:
INSTR(‘CORPORATE FLOOR‘,‘OR‘, 3, 2)中,源字符串为‘CORPORATE FLOOR‘, 目标字符串为‘OR‘,起始位置为3,取第2个匹配项的位置;返回结果为 14 ‘

测试字段实例:

表:cheyang.content=’ request="" PackId="" PackPlanId="100003624470" sFlag="1" ‘

要求:截取PackPlanId的vlaue值

  select substr(planid, 0, instr(planid, ‘"‘, 1, 1) - 1) planid  --planid(100003624470" sFlag=)截取”之前的字符串
    into v_PackPlanId
  from (select substr(content,INSTR(content, ‘PackPlanId‘, 1, 1) + 11+1,20) planid   --packPlanId=长度是11+1(1),向后截取20个字符
  from sducy.cheyang
  where t.oid = v_oid);

测试结果:

  planid

  100003624470

 






















以上是关于Oracle截取字符串和查找字符串,联合使用截取特定字符的主要内容,如果未能解决你的问题,请参考以下文章

oracle字符串操作:拼接替换截取查找

oracle操作字符串:拼接替换截取查找

oracle里从右截取字符,ORACLE怎么截取字符串例如有一个位字符串

Oracle中字符串截取最全方法总结

Oracle中字符串截取常用方法总结

oracle怎样查找某个字符所在字符串第n次出现的位置