Oracle中函数/过程返回结果集的几种方式
来源:互联网 发布:个人定位软件 编辑:程序博客网 时间:2024/05/16 23:34
Oracle中函数/过程返回结果集的几种方式:
以函数return为例,存储过程只需改为out参数即可,在oracle 10g测试通过.
(1) 返回游标:
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 <<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'));
阅读全文
0 0
- Oracle中函数/过程返回结果集的几种方式
- Oracle中函数/过程返回结果集的几种方式
- Oracle中函数/过程返回结果集的几种方式:
- Oracle中函数/过程返回结果集的几种方式
- Oracle中过程/函数返回结果集
- Oracle中过程/函数返回结果集
- Oracle中过程/函数返回结果集
- Oracle中过程/函数返回结果集
- ORACLE存储过程返回结果集的方式
- 数据结果集的返回的几种方式
- Oracle中返回结果集的存储过程
- Oracle中返回结果集的存储过程
- Oracle中返回结果集的存储过程分享
- SQL Server 返回结果集的几种方式
- oracle 返回结果集的存储过程
- Oracle的存储过程返回结果集
- Oracle 中,函数如何返回结果集
- C#调用ORACLE存储过程返回结果集及函数
- [Leetcode] 376. Wiggle Subsequence 解题报告
- java垃圾回收机制笔记
- UVA
- 生成模型、最大化似然、KL散度
- 使用MyEclipse开发Java EE应用:用XDoclet创建EJB 2 Session Bean项目(三)
- Oracle中函数/过程返回结果集的几种方式
- 最大差值
- 机器学习笔记——感知机算法的几点总结
- 2017多校训练赛第九场 HDU 6162(LCA+Treap解法)
- shiro权限标签在页面中的应用
- [JAVAWEB]7.JSP文件的构成(二)
- Vimer 的福音:Mac 下 Caps + hjkl 作为方向键
- subic项目总结(一)-quartz库表
- AsyncTask加载网络数据