Oracle中函數/過程返回多個值(結果集)

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

相關文章
相關標籤/搜索