zoukankan      html  css  js  c++  java
  • Oracle截取字符串和查找字符串,联合使用截取特定字符

    oracle 截取字符(substr),检索字符位置(instr) case when then else end语句使用 收藏 
    常用函数:substr和instr
    1.SUBSTR(string,start_position,[length])    求子字符串,返回字符串
    解释:string 元字符串
           start_position   开始位置(当开始位置是0或者1时,都表示从第一个字符开始截取)
           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:查找的开始位置(从1开始)
          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

    3.组合使用instr和substr

      原串src:{"VALUE":"5"}

    要求取出value对应的值:5

      select substr(src,instr(src,'"',1,3)+1,instr(src,'"',1,4)-1-instr(src,'"',1,3)) value  from dual;

    测试结果:

      vale

       5

    处理说明:

      截取开始位置:instr(src,'"',1,3)+1    //从第三个字符“后一个字符开始,

      截取字符长度:instr(src,'"',1,4)-1-instr(src,'"',1,3)    //从第4个字符“的前一个字符下标长度为串的长度,减去开始位置下标,获得需要截取字符串的长度。

  • 相关阅读:
    oracle数据库查看修改字符集问题
    C/C++内存问题检查利器—Purify (五)
    C/C++内存问题检查利器—Purify (四)
    C/C++内存问题检查利器—Purify (三)
    Oracle 字符集的查看和修改
    C/C++内存问题检查利器—Purify (二)
    linux内存管理之活动内存区
    C/C++内存问题检查利器—Purify (一)
    postman——基础操作——API请求与响应——API响应
    postman——基础操作——History选项卡
  • 原文地址:https://www.cnblogs.com/cyblogs/p/5983612.html
Copyright © 2011-2022 走看看