• 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 '

    1、substr("ABCDEFG", 0, -3); //返回:EFG,注意参数-3,为负值时表示从尾部开始算起,字符串排列位置不变。

    这个应该去掉0,否则,取到的值为null

    原文http://blog.csdn.net/caozhongyan/article/details/6607798

    切割字符串,一般是不会通过数据库函数来处理的(大部分是查询出结果后通过代码处理的),但是也有特殊的情况;

    比如:Oracle数据库有一张表Node,字段有:

    ID:主键

    parentID:父节点

    STATID:查询编码

    NAME:名称

    STATNAME:查询名字

    SCALE:父子级别

    看的出,这是张存储父子结构关系的表,而STATID的左右就是把父子结构的关系拼接起来:比如,某记录为:

    ID   parentID    STATID   NAME            STATNAME                 SCALE

    01                1       华南             华南                      1

    03      01        1s3      上海             华南s上海                2

    05      03        1s3s5    浦东新区        华南s上海s浦东新区        3

    很容易看的出三条记录的父子结构,而STATID就是把当前记录的所有父节点的ID,用's'连接起来;比如ID=05的记录是“浦东新区”,是第三级的节点,它的父节点即二级节点是ID=03的“上海”,而“上海”的父节点即一级节点是ID=01的“华南”,这时“浦东新区”的STATID 就是1s3s5   

    以此表为例,分割STATID!

    常用函数:substr和instr

    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", 0, -3); //返回:EFG,注意参数-3,为负值时表示从尾部开始算起,字符串排列位置不变

    INSTR(string,subString,position,ocurrence)查找字符串位置

    解释:string:源字符串

          subString:要查找的子字符串

          position:查找的开始位置

          ocurrence:源字符串中第几次出现的子字符串

    For example:

    INSTR('CORPORATE FLOOR','OR', 3, 2)中,源字符串为'CORPORATE FLOOR', 目标字符串为'OR',起始位置为3,取第2个匹配项的位置;返回结果为 14

    由上面两个函数就可以进行字符串的切割了!

    比如SQL如下:

    select n.ID,n.parentid,n.statid,n.name
       substr(n.statid,instr(n.statid,'s',1,2)+1,(instr(n.statid,'s',1,3)-instr   (n.statid,'s',1,2)-1)) market_id
       from node n

    注意:上面查找的就是statid中所有三级节点的ID值

           所有,真实使用中一定注意,只有三级(包含三级)以上的节点才有market_id值

    ==========================================================================================================================

     

    declare aa varchar2 := 'wkressssdfdf';

    begin

    if instr(aa,'s')>0 then

    dbms_output.put_line('有s字符');

    else dbms_output.put_line('没有s字符');

    end if;

    end;

  • 相关阅读:
    验车流程
    WLK毁灭术士天赋图及输出手法
    一个类型集合操作SYS_REFCURSOR的例子
    关于法师真正的输出手法个人观点
    FS技能快界键的设置
    MODEL函数的简单用法。
    kevin的黎明十分
    Android9.0动态运行时权限源码分析及封装改造<四>打造自己的权限申请框架下
    电子书资源
    批量消除图片的杂色背景
  • 原文地址:https://www.cnblogs.com/kingxiaozi/p/3727044.html
Copyright © 2020-2023  润新知