Oracle中函数/过程返回多个值(结果集)
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Oracle中函数/过程返回多个值(结果集),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2427字,纯文字阅读大概需要4分钟。
内容图文
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‘));
转自 http://blog.csdn.net/feiliu010/article/details/1538822
Oracle中函数/过程返回多个值(结果集)
标签:
本文系统来源:http://www.cnblogs.com/zheng-hong-bo/p/4563845.html
内容总结
以上是互联网集市为您收集整理的Oracle中函数/过程返回多个值(结果集)全部内容,希望文章能够帮你解决Oracle中函数/过程返回多个值(结果集)所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。