存储过程的输出是游标(列表)



create or replace PACKAGE PLSQLPACKAGE AS

  --必须在包中声明输出用游标

  type Test_CURSOR is ref cursor ;

 
  PROCEDURE PROC3( p_CURSOR OUT Test_CURSOR);

END PLSQLPACKAGE;


create or replace
PACKAGE BODY PLSQLPACKAGE AS

  PROCEDURE PROC3 ( p_CURSOR OUT Test_CURSOR) AS
  BEGIN
    --在过程中打开游标

    OPEN p_CURSOR FOR SELECT * FROM TB_USERTEST;
  END PROC3;
 
END PLSQLPACKAGE;


--测试用代码

DECLARE
  P_CURSOR PLSQLPACKAGE.Test_CURSOR;
  user_id_var number(5,0);
  user_name_var varchar2(20);
  user_add_var varchar2(20);
  user_phone_var varchar2(20);
BEGIN

  PLSQLPACKAGE.PROC3(
    P_CURSOR => P_CURSOR
  );
  fetch P_CURSOR into user_id_var, user_name_var, user_add_var, user_phone_var;
  while P_CURSOR%FOUND loop
    DBMS_OUTPUT.PUT_LINE('ID = ' || user_id_var || ' NAME = ' || user_name_var || ' ADD = ' || user_add_var || ' PHONE = ' || user_phone_var);
    fetch P_CURSOR into user_id_var, user_name_var, user_add_var, user_phone_var;
  end loop;

  --关闭游标
  close P_CURSOR;
END;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值