Oracle中函數/過程返回結果集的幾種方式: oracle
以函數return爲例,存儲過程只需改成out參數便可,在oracle 10g測試經過. 函數
(1) 返回遊標:oop
return的類型爲:SYS_REFCURSOR測試
以後在IS裏面定義變量:curr SYS_REFCURSOR;this
最後在函數體中寫: open cur for select ......; return cur; spa
例: .net
CREATE OR REPLACE FUNCTION A_Test(orType varchar2) RETURN SYS_REFCURSOR is type_cur SYS_REFCURSOR; BEGIN OPEN type_cur FOR select col1,col2,col3 from testTable ; RETURN type_cur; END;
(2)返回table類型的結果集: rest
首先定義一個行類型:code
CREATE OR REPLACE TYPE "SPLIT_ARR" AS OBJECT(nowStr varchar2(18))
其次以此行類型定義一個表類型: 對象
CREATE OR REPLACE TYPE "SPLIT_TAB" AS TABLE of split_arr;
定義函數(此函數完成字符串拆分功能):
CREATE OR REPLACE FUNCTION GetSubStr(str in varchar2, --待分割的字符串 splitchar in varchar2 --分割標誌 ) return split_tab IS restStr varchar2(2000) default GetSubStr.str; --剩餘的字符串 thisStr varchar2(18); --取得的當前字符串 indexStr int; --臨時存放分隔符在字符串中的位置 v split_tab := split_tab(); --返回結果 begin dbms_output.put_line(restStr); while length(restStr) != 0 LOOP <<top>> indexStr := instr(restStr, splitchar); --從子串中取分隔符的第一個位置 if indexStr = 0 and length(restStr) != 0 then --在剩餘的串中找不到分隔符 begin v.extend; v(v.count) := split_arr(Reststr); return v; end; end if; if indexStr = 1 then ---第一個字符便爲分隔符,此時去掉分隔符 begin restStr := substr(restStr, 2); goto top; end; end if; if length(restStr) = 0 or restStr is null then return v; end if; v.extend; thisStr := substr(restStr, 1, indexStr - 1); --取得當前的字符串 restStr := substr(restStr, indexStr + 1); ---取剩餘的字符串 v(v.count) := split_arr(thisStr); END LOOP; return v; end;
在PL/SQL developer中能夠直接調用
cursor strcur is select nowStr from Table(GetSubStr('111,222,333,,,',','));
(3)以管道形式輸出:
create type row_type as object ( a varchar2(10), v varchar2(10) ) ; --定義行對象 create type table_type as table of row_type; --定義表對象 create or replace function test_fun(a in varchar2, b in varchar2) return table_type pipelined is v row_type; --定義v爲行對象類型 begin for thisrow in (select a, b from mytable where col1 = a and col2 = b) loop v := row_type(thisrow.a, thisrow.b); pipe row(v); end loop; return; end; select * from table(test_fun('123', '456'));
轉自 http://blog.csdn.net/feiliu010/article/details/1538822