如果在程序运行中,需要输出进度等相关信息,可以使用Oracle提供的Pipe功能。
首先,创建一个Type。
create or replace type msg as table of varchar2(20)
/
然后,创建函数
create or replace function display (v_count in integer)
return msg PIPELINED
as
begin
for x in 1..v_count loop
pipe row(x);
DBMS_LOCK.sleep(1);
end loop;
end;
/
这个例子需要DBMS_LOCK的权限,如果没有权限,可以使用DBA账号进行授权。
grant execute on dbms_lock to lihuilin;
Sqlplus中运行:
set arraysize 1;
select * from table(display(10));
即可看到运行结果。
首先,创建一个Type。
create or replace type msg as table of varchar2(20)
/
然后,创建函数
create or replace function display (v_count in integer)
return msg PIPELINED
as
begin
for x in 1..v_count loop
pipe row(x);
DBMS_LOCK.sleep(1);
end loop;
end;
/
这个例子需要DBMS_LOCK的权限,如果没有权限,可以使用DBA账号进行授权。
grant execute on dbms_lock to lihuilin;
Sqlplus中运行:
set arraysize 1;
select * from table(display(10));
即可看到运行结果。
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29254281/viewspace-776047/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/29254281/viewspace-776047/