Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1372476
  • 博文数量: 205
  • 博客积分: 6732
  • 博客等级: 准将
  • 技术积分: 2835
  • 用 户 组: 普通用户
  • 注册时间: 2008-09-04 17:59
文章分类

全部博文(205)

文章存档

2016年(1)

2015年(10)

2014年(1)

2013年(39)

2012年(23)

2011年(27)

2010年(21)

2009年(55)

2008年(28)

我的朋友

分类: Oracle

2009-07-09 14:28:46

--创建一个type,如果为了使split函数具有通用性,请将其size 设大些
create or replace type type_split as table of varchar2(2000);

--创建function
create or replace function split
(
   p_list varchar2,
   p_sep varchar2 := ','
) return type_split pipelined
 is
   l_idx pls_integer;
   v_list varchar2(2000) := p_list;
begin
   loop
      l_idx := instr(v_list,p_sep);
      if l_idx > 0 then
          pipe row(substr(v_list,1,l_idx-1));
          v_list := substr(v_list,l_idx+length(p_sep));
      else
          pipe row(v_list);
          exit;
      end if;
   end loop;
   return;
end split;


--测试
select * from table(split('northsnow,塞北的雪',','));

阅读(1385) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~