Oracle 系列:REF Cursor函數
在上文 Oracle 系列:Cursor (參見:http://blog.csdn.net/qfs_v/archive/2008/05/06/2404794.aspx)中
提到個思考:怎樣讓遊標做爲參數傳遞? 解決這個問題就須要用到 REF Cursor 。oop
1,什麼是 REF遊標 ?
動態關聯結果集的臨時對象。即在運行的時候動態決定執行查詢。
2,REF 遊標 有什麼做用?
實如今程序間傳遞結果集的功能,利用REF CURSOR也能夠實現BULK SQL,從而提升SQL性能。性能
3,靜態遊標和REF 遊標的區別是什麼?
①靜態遊標是靜態定義,REF 遊標是動態關聯;
②使用REF 遊標需REF 遊標變量。
③REF 遊標能作爲參數進行傳遞,而靜態遊標是不可能的。
4,什麼是REF 遊標變量?
REF遊標變量是一種 引用 REF遊標類型 的變量,指向動態關聯的結果集。fetch
5,怎麼使用 REF遊標 ?
①聲明REF 遊標類型,肯定REF 遊標類型;
⑴強類型REF遊標:指定retrun type,REF 遊標變量的類型必須和return type一致。
語法:Type REF遊標名 IS Ref Cursor Return 結果集返回記錄類型;
⑵弱類型REF遊標:不指定return type,能和任何類型的CURSOR變量匹配,用於獲取任何結果集。
語法:Type REF遊標名 IS Ref Cursor;spa
②聲明Ref 遊標類型變量;
語法:變量名 已聲明Ref 遊標類型;
③打開REF遊標,關聯結果集 ;
語法:Open Ref 遊標類型變量 For 查詢語句返回結果集;
④獲取記錄,操做記錄;
語法:Fatch REF遊標名 InTo 臨時記錄類型變量或屬性類型變量列表;
⑤關閉遊標,徹底釋放資源;
語法:Close REF遊標名;
例子:強類型REF遊標
/*conn scott/tiger*/
Declare
Type MyRefCurA IS REF CURSOR RETURN emp%RowType;
Type MyRefCurB IS REF CURSOR RETURN emp.ename%Type;
vRefCurA MyRefCurA;
vRefCurB MyRefCurB;
vTempA vRefCurA%RowType;
vTempB vRefCurB.ename%Type;
Begin
Open vRefCurA For Select * from emp Where SAL > 2000;
Loop
Fatch vRefCurA InTo vTempA;
Exit When vRefCurA%NotFound;
DBMS_OUTPUT.PUT_LINE(vRefCurA%RowCount||' '|| vTempA.eno||' '||vTempA.ename ||' '||vTempA.sal)
End Loop;
Close vRefCurA;
DBMS_OUTPUT.PUT_LINE('-------------------------------------------------------------------------------------------------------');
Open vRefCurB For Select ename from emp Where SAL > 2000;
Loop
Fatch vRefCurB InTo vTempB;
Exit When vRefCurB%NotFound;
DBMS_OUTPUT.PUT_LINE(vRefCurB%RowCount||' '||vTempB)
End Loop;
Close vRefCurB;
DBMS_OUTPUT.PUT_LINE('-------------------------------------------------------------------------------------------------------');
Open vRefCurA For Select * from emp Where JOB = 'CLERK';
Loop
Fatch vRefCurA InTo vTempA;
Exit When vRefCurA%NotFound;
DBMS_OUTPUT.PUT_LINE(vRefCurA%RowCount||' '|| vTempA.eno||' '||vTempA.ename ||' '||vTempA.sal)
End Loop;
Close vRefCurA;
End;
例子:弱類型REF遊標
/*conn scott/tiger*/
Declare
Type MyRefCur IS Ref Cursor;
vRefCur MyRefCur;
vtemp vRefCur%RowType;
Begin
Case(&n)
When 1 Then Open vRefCur For Select * from emp;
When 2 Then Open vRefCur For Select * from dept;
Else
Open vRefCur For Select eno, ename from emp Where JOB = 'CLERK';
End Case;
Close vRefCur;
End;.net
6,怎樣讓REF遊標做爲參數傳遞?對象
--做爲函數返回值
create or replace function returnacursor return sys_refcursor
is
v_csr sys_refcursor;
begin
open v_csr for select a1 from test3;
return v_csr;
end;
/blog
declare
c sys_refcursor;
a1 char(2);
begin
c:=returnacursor;
loop
fetch c into a1;
exit when c%notfound;
dbms_output.put_line(a1);
end loop;
close c;
end;
/資源
--做爲參數
create or replace procedure proc_ref_cursor (rc in sys_refcursor) as
v_a number;
v_b varchar2(10);
begin
loop
fetch rc into v_a, v_b;
exit when rc%notfound;
dbms_output.put_line(v_a || ' ' || v_b);
end loop;
end;
/get
declare v_rc sys_refcursor; begin open v_rc for select a1,a2 from test3; proc_ref_cursor(v_rc); close v_rc; end; /