欢迎投稿

今日深度:

Oracle中分割字符串的方法实例代码,

Oracle中分割字符串的方法实例代码,


目录
  • 1. 使用 regexp_substr() 函数
    • 1.1 方式1
    • 1.2 方式2
    • 1.3 注意问题(尤其是存储过程中用到,可能会入坑)
  • 2. 自定义函数
    • 2.1 自定义类型 table
    • 2.2 自定义函数
      • 2.2.1 自定义函数
      • 2.2.2 效果如下:
    • 2.3 Oracle查看<Collection> 类型数据
    • 总结

      1. 使用 regexp_substr() 函数

      1.1 方式1

      如下:

      select regexp_substr('bbb,aaa,ccc', '[^,]+', 1, level) as split_result
        from dual
      connect by level <=
                 length('bbb,aaa,ccc') - length(replace('bbb,aaa,ccc', ',')) + 1;
      

      1.2 方式2

      如下:

      select regexp_substr(replace('aaa;bbb;ccb', '', ';'), '[^;]+', 1, level) as split_result
         from dual
       connect by level <= regexp_count('aaa;bb;', ';') + 1;
      

      或者 with 写法,如下

      with temp as
       (select 'bbb,aaa,ccc' as str from dual)
      select regexp_substr(replace(str, ',', ' ,'), '[^,]+', 1, level)
        from temp
      connect by level <= regexp_count(str, ',') + 1
      

      1.3 注意问题(尤其是存储过程中用到,可能会入坑)

      问题情况(可能会出现空行),如下:

      解决问题:

      上述空行不是我们所需要的,所以排除即可,如下:

      select split_result,length(split_result) from (
       select regexp_substr(replace('aaa;bb;', '', ';'), '[^;]+', 1, level) as split_result
         from dual
       connect by level <= regexp_count('aaa;bb;', ';') + 1)
       where split_result is not null;
      

      2. 自定义函数

      2.1 自定义类型 table

      如下:

      create or replace type result_split_list as table of varchar2(100);
      

      2.2 自定义函数

      2.2.1 自定义函数

      如下:

      create or replace function split_strs(strs varchar2, type_split varchar2)
        return result_split_list
        pipelined is
        index_num  pls_integer;
        str_list varchar2(100) := strs;
      begin
        loop
          index_num := instr(str_list, type_split);
          if index_num > 0 then
            pipe row(substr(str_list, 1, index_num - 1));
            str_list := substr(str_list, index_num + length(type_split));
          else
            pipe row(str_list);
            exit;
          end if;
        end loop;
        return;
      end split_strs;
      

      2.2.2 效果如下:

      如下:

      2.3 Oracle查看<Collection> 类型数据

      上面的效果我们看到查看到的是<Collection> 类型,不方便查看数据,处理如下:

      select * from table (select split_strs('aaa,bbb,ccc',',') from dual);
      

      总结

      到此这篇关于Oracle中分割字符串的方法的文章就介绍到这了,更多相关Oracle分割字符串内容请搜索PHP之友以前的文章或继续浏览下面的相关文章希望大家以后多多支持PHP之友!

      您可能感兴趣的文章:
      • Oracle通过正则表达式分割字符串 REGEXP_SUBSTR的代码详解
      • Oracle 两个逗号分割的字符串,获取交集、差集(sql实现过程解析)

      www.htsjk.Com true http://www.htsjk.com/oracle/45353.html NewsArticle Oracle中分割字符串的方法实例代码, 目录 1. 使用 regexp_substr() 函数 1.1 方式1 1.2 方式2 1.3 注意问题(尤其是存储过程中用到,可能会入坑) 2. 自定义函数 2.1 自定义类型 table 2.2 自定义...
      评论暂时关闭