在oracle中手动创建split函数
来源:互联网 发布:网络直复营销 编辑:程序博客网 时间:2024/05/22 07:08
为了让 PL/SQL 函数返回数据的多个行,可以通过返回一个 REF CURSOR 或一个数据集合来完成。REF CURSOR 的这种情况局限于可以从查询中选择的数据,而整个集合在可以返回前,必须进行具体化。ORACLE 9i 通过引入的管道化表函数纠正了后一种情况。表函数是返回整个行的集(通常作为一个集合)的函数,可以直接从 SQL 语句中进行查询,就好像它是一个真正的数据库表一样。管道化表函数与之相似,但是它像在构建时一样返回数据,而不是一次全部返回。管道化表函数更加有效,因为数据可以尽可能快地返回。
管道化表函数必须返回一个集合。在函数中,PIPE ROW 语句被用来返回该集合的单个元素,该函数必须以一个空的 RETURN 语句结束,以表明它已经完成。一旦我们创建了上述函数,我们就可以使用 TABLE 操作符从 SQL 查询中调用它。
管道化表函数经常被用来把数据从一种类型转化成另一种类型。
create or replace package pk_Base is
type t_split_tbl is table of varchar2(32767);
function split(p_list varchar2,p_del varchar2 := ',')
return t_split_tbl pipelined;
end pk_Base;
/
type t_split_tbl is table of varchar2(32767);
function split(p_list varchar2,p_del varchar2 := ',')
return t_split_tbl pipelined;
end pk_Base;
/
create or replace package body pk_Base is
function split(p_list varchar2,p_del varchar2 := ',')
return t_split_tbl pipelined
is
l_idx pls_integer;
l_list varchar2(32767) := p_list;
l_value varchar2(32767);
begin
loop
l_idx := instr(l_list,p_del);
if l_idx > 0 then
pipe row(substr(l_list,1,l_idx-1));
l_list := substr(l_list,l_idx+length(p_del));
else
pipe row(l_list);
exit;
end if;
end loop;
return;
end;
end pk_Base;
/
function split(p_list varchar2,p_del varchar2 := ',')
return t_split_tbl pipelined
is
l_idx pls_integer;
l_list varchar2(32767) := p_list;
l_value varchar2(32767);
begin
loop
l_idx := instr(l_list,p_del);
if l_idx > 0 then
pipe row(substr(l_list,1,l_idx-1));
l_list := substr(l_list,l_idx+length(p_del));
else
pipe row(l_list);
exit;
end if;
end loop;
return;
end;
end pk_Base;
/
测试:select * from table (pk_Base.split('1,12,123,1234,12345'));
结果:
1
12
123
1234
12345
1
12
123
1234
12345
注意:以上函数仅限于oracle9i及其以上版本!
- 在oracle中手动创建split函数
- 在oracle创建Split和Map函数
- 创建oracle的split函数
- Oracle中使用Split函数
- Oracle中增加Split函数
- Oracle 创建 split 和 splitstr 函数
- Oracle 创建 split 和 splitstr 函数
- Oracle 创建 split 和 splitstr 函数
- 在MSSQL的创建Split函数
- 在atom中手动创建maven项目
- oracle中创建函数
- oracle中创建函数
- oracle split函数
- Oracle 实现split函数
- Oracle中的Split函数
- Oracle Split功能函数
- oracle实现split函数
- oracle的split函数
- “在 TCP 网络上检测出有重复名称”错误的解决方法
- 针尖上的Web服务器
- Portal开源实现-Liferay的Portlet Session处理(1)
- VC++下对匿名管道的编程实现
- oracle10g新特性:闪回恢复区(Flash recovery area)
- 在oracle中手动创建split函数
- C++面试题1
- 社区英雄榜:谁是最有价值的技术博客?
- 精妙Sql语句
- 开源有益——爱上Spring的5个理由
- Portal开源实现-Liferay的Portlet Session处理(2)
- 升级oracle客户端后exp数据异常的解决办法
- MFC的DLL
- 软件开发之职业规划