oracle 返回 table,oracle 存储过程返回 结果集 table形式的案例

本文介绍了Oracle中sys_refcursor与cursor的区别,强调了sys_refcursor在作为参数传递和面向对象编程中的优势。通过示例展示了如何创建存储过程返回sys_refcursor类型的查询结果,并提供了在.NET中调用该存储过程获取数据的代码片段。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

--sys_refcursor 和 cursor 优缺点比较

优点比较

优点一:

sys_refcursor,可以在存储过程中作为参数返回一个table格式的结构集(我把他认为是table类型,容易理解,其实是一个游标集), cursor 只能用在存储过程,函数,包等的实现体中,不能做参数使用。

优点二:

sys_refcursor 这东西可以使用在包中做参数,进行数据库面向对象开放。哈哈。我喜欢。cursor就不能。

create or replace procedure p_test(p_cur out sys_refcursor)

as

begin

open p_cur for select * from emp;

end p_test;

declare

p_cur sys_refcursor;

i emp%rowtype;

begin

p_test(p_cur);

loop fetch p_cur

into i;

exit when p_cur%notfound;

DBMS_OUTPUT.PUT_LINE('---'||i.ename||'---'||i.empno);

end loop;

close p_cur;

end;

补充:Oracle存储过程返回select * from table结果

1.首先建立一个包

create or replace package LogOperation is

type listLog is ref cursor;

procedure PCenterExamine_sel(listCenterExamine out listlog,testlist out listLog,numpage in decimal);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值