我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

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;

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

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;

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

或者 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

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

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

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

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

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

解决问题:

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

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;

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

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

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;

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

2.2.2 效果如下:

如下:

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

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

2.3 Oracle查看<Collection> 类型数据

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

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

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

总结

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

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

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

目录1. 使用 regexp_substr() 函数1.1 方式11.2 方式21.3 注意问题(尤其是存储过程中用到,可能会入坑)2. 自定义函数2.1 自定义类型 table2.2 自定义函数2.2.1 自定义函数2.2.2 效果如下:
2023-02-15

javascript分割字符串的方法

这篇文章给大家分享的是有关javascript分割字符串的方法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。分割方法:1、用“string.split(分割符)”;2、用“String.substring(开始位
2023-06-14

python中partition分割字符串的方法

小编给大家分享一下python中partition分割字符串的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1、说明根据指定的分隔符分割文字符串。如果字串中含
2023-06-15

Golang 分割字符串的实现示例

本文主要介绍了Golang 分割字符串的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-05-17

Java中实现String字符串分割的3种方法

这篇文章主要介绍了Java中实现String字符串分割的3种方法,文章底部介绍了JAVA 截取字符串的三种方法subString,StringUtils,split,本文结合实例代码给大家介绍的非常详细,需要的朋友可以参考下
2023-05-20

在Shell中分割字符串的例子

比如,要分割 test=”aaa,bbb,cc cc,dd dd”,可以这样 arr=$(echo $test|tr "," "n") 还可以这样 OLD_IFS=$IFSIFS=','arr=$testIFS=$OLD_IFS 然后用 f
2022-06-04

java分割文本字符串的方法

问题:在项目中,当保存数据超过数据库字段列长度限制时,如何解决?一种常见的解决办法是:截串存取。顾名思义,就是对大文本数据按指定长度进行截取,返回结果集依截取顺序存储在新表中。并通过在新表中创建一个type字段来标识新表中截取的内容对应旧表
2023-05-31

shell 使用指定的分割符来分割字符串的方法

shell 如何用指定的分隔符来分割字符串让结果为一个字符串数组,类似 java 中的 split, 而 split 关键字已经留给文件分割了,故字符串就分割处理就不能在使用了,那如何来处理字符串串分http://www.cppcns.co
2022-06-04

Python删除字符串中字符的四种方法示例代码

这篇文章主要介绍了Python删除字符串中字符的四种方法,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2022-12-08

Java字符串的截取和分割方法

这篇文章主要讲解了“Java字符串的截取和分割方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java字符串的截取和分割方法”吧!一、字符串的截取和分割1.在程序开发中,有些时候我们需要对
2023-06-15

MySQL字符串拼接与分组拼接字符串实例代码

目录一、经典拼接concat(x,x,....)二、分隔符拼接CONCAT_WS(separator,str1,str2,...)三、分组拼接GROUP_CONCAT(expr)补充:在筛选查询中进行字符串拼接并显示在表格里总结一、经典拼接
2023-02-02

编程热搜

目录