使用pipeline function获得实时输出

使用pipeline function获得实时输出

在普通的函数中,使用dbms_output输出的信息,需要在服务器执行完整个函数后一次性的返回给客户端。如果需要在客户端实时的输出函数执行过程中的一些信息,在oracle9i以后可以使用管道函数(pipeline function)。

关键字PIPELINED表明这是一个管道函数,管道函数的返回值类型必须为集合,在函数中,PIPE ROW语句被用来返回该集合的单个元素,函数以一个空的 RETURN 语句结束,以表明它已经完成。

create or replace type MsgType as table of varchar2(4000);
/

create or replace function f_pipeline_test
return MsgType
PIPELINED
as
begin
    for i in 1 .. 10
    loop
        pipe row( 'Iteration ' || i || ' at ' || systimestamp );
        dbms_lock.sleep(1);
    end loop;
    pipe row( 'All done!' );
    return;
end;
/

[继续阅读全文]