return的类型为:SYS_REFCURSOR

之后在IS里面定义变量:curr SYS_REFCURSOR;

最后在函数体中写:          open cur for             select ......;          return cur;

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类型的结果集:

首先定义一个行类型:

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
    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

转载于:https://www.cnblogs.com/zheng-hong-bo/p/4563845.html

Oracle中函数/过程返回结果集的几种方式: 以函数return为例,存储过程只需改为out参数即可,在oracle 10g测试通过. (1) 返回游标:return的类型为:SYS_REFCURSOR之后在IS里面定义变量:curr SYS_REFCURSOR;最后在函数体中写: open cur for select ...
一.存储 过程 (PROCEDURE)   使用 过程 , 不仅可以简化客户端应用程序的开发和维护,而且可以提高应用程序的运行性能.   CREATE [OR REPLACE] PROCUDURE procedure_name   (arg1 [model1] datatype1, arg2[model2] datatype2)   IS [AS]   PL/SQL...
Oracle 存储 过程 返回 结果 都是以SYS_REFCURSOR的方式 返回 的,我们一般看不到这个 返回 的具体内容,今天我们换了一种变通的方式来处理存储 过程 返回 的结果 ,让我们在PL/SQL 可以查看 Oracle 自定义 函数 返回 的结果 。具体做法是创建自定义 函数 ,由 函数 返回 的结果 去看SYS_REFCURSOR的内容。首先我们先建立一个测试环境创建测试表:Create Table App_TEST 2.实现 过程 2.1REGEXP_SUBSTR() function REGEXP_SUBSTR(String, pattern, position, occurrence, modifier) string:需要进行正则处理的字符串 pattern:进行匹配的正则表达式 position:起始位置,从字符串的第几个字符开始正则表达式匹配(默认为1) 注意:字符串最初的位置是1而不是0 occurrence:获取第几个分割出来的组
mysql --secure-file-priv is set to NULL.Operations related to importing and exporting data are disa... 13910