zoukankan      html  css  js  c++  java
  • EBS_SQL_技巧:截断

    一:理论

    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 '

    二:实际测试

    select substr('OR:com.lcs.wc.placeholder.Placeholder:860825',INSTR('OR:com.lcs.wc.placeholder.Placeholder:860825',':', 1, 2)+1,length('OR:com.lcs.wc.placeholder.Placeholder:860825'))
    ,INSTR('OR:com.lcs.wc.placeholder.Placeholder:860825',':', 1, 2),
    length('OR:com.lcs.wc.placeholder.Placeholder:860825') From dual;

    CREATE TABLE test (name VARCHAR2 (32)); 

    insert into test values('CA-CA1344-A-11OCT141250-D');  

    insert into test values('JD-JD693-A-11OCT141105-D');  

    方法1:

    select substr(name,instr(name,'-',1)+1,instr(name,'-',instr(name,'-',1)+1)-instr(name,'-',1)-1) from test;  

    方法2:

    select substr(name,instr(name,'-',1,1)+1,instr(name,'-',1,2)-1-instr(name,'-',1,1)) from test;

    接下我们再写一下,取第二个"-"到第三个"-"之间的字符串的方法:

    select substr(name,instr(name,'-',2,2)+1,instr(name,'-',2,3)-1-instr(name,'-',2,2)) from test; 

  • 相关阅读:
    Kafka文件存储机制那些事(转发)
    Kafka文件存储机制那些事(转发)
    消息队列设计精要(转发)
    RocketMQ原理解析-Broker(转发)
    Apache Kafka:下一代分布式消息系统(转发)
    新浪技术分享:我们如何扛下32亿条实时日志的分析处理(转发)
    消息队列技术介绍(转发)
    confluent kafka for .net
    kafka参考资料
    kafka架构(转发)
  • 原文地址:https://www.cnblogs.com/hopedba/p/5951713.html
Copyright © 2011-2022 走看看