oracle中使用自定义函数解析指定分隔符的字符串

本文介绍如何在Oracle数据库中使用自定义函数实现字符串的拆分,包括创建字符串表类型、管道函数,并通过示例展示如何使用该函数进行字符串的拆分。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.创建字符串表类型

create type tab_varchar is table of varchar2(2000);

2.创建管道函数

create or replace function get_split_str(p_str varchar2, p_sep varchar2 default ',')
return tab_varchar pipelined
/**
  作者:laoxu
  功能:字符串分隔管道函数
  p_str    源字符串
  p_sep 分隔符,默认为逗号
*/
is
l_idx int:=0;
v_list varchar2(4000) := p_str;
begin
 loop
   l_idx := instr(v_list,p_sep);
   
   --没找到分隔符
   if l_idx = 0 then
     pipe row(v_list);
     return;
   --分隔符是第一个字符
   elsif l_idx = 1 then
        v_list := substr(v_list,l_idx+length(p_sep));
   --分隔符是最后一个字符
   elsif l_idx = length(v_list) then
       pipe row(substr(v_list,1,l_idx-1));
       return;
   else
   --打印第一个逗号之前的字符,然后继续执行
     pipe row(substr(v_list,1,l_idx-1));
     v_list := substr(v_list,l_idx+length(p_sep));
   end if;
  end loop;
end;


3.测试

select column_value from table(get_split_str(',111,123,234,'));

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值