ORACLE之PACKAGE-游标变量

刚学pl/sql编程,写了两个package。pkg_temp_fn31和pkg_temp_fn32。内容涉及pl/sql基本语法,游标变量,存储过程(in,out)。

  pkg_temp_fn31调用pkg_temp_fn32,pkg_temp_fn32中定义了out游标变量。

  • pkg_temp_fn31内有一个procedure test(p_mapid number)

  创建包规范

1 create or replace package pkg_temp_fn31 is
2   --25-03-2016 
3   procedure test(p_mapid number);
4 end pkg_temp_fn31;
5 --exec pkg_temp_fn31.test(&p_mapid);执行此包

  创建包体pkg_temp_fn31

create or replace package body pkg_temp_fn31
is
 procedure test(p_mapid number) is
  p_cursor pkg_temp_fn32.ref_cursor;--
  p_personno t_fn_person.person_code%type;
  p_personname t_fn_person.person_name%type;
  begin
    pkg_temp_fn32.queryall(p_mapid,p_cursor);--
    loop
      fetch p_cursor into p_personno,p_personname;
      exit when p_cursor%notfound;
      dbms_output.put_line(p_personno||'''s person name is '||p_personname);  
    end loop;   
  end test;
end pkg_temp_fn31;

 

  • kg_temp_fn32内有一个procedure queryall(pmap_id number ,p_cursor out ref_cursor)

  创建包规范  

1 create or replace package pkg_temp_fn32 is
2 --25/03/2016
3   type ref_cursor is ref cursor;--
4   procedure queryall(pmap_id number ,p_cursor out ref_cursor);
5 end pkg_temp_fn32;

  创建包体pkg_temp_fn32

create or replace package body pkg_temp_fn32 is
procedure queryall(pmap_id number ,p_cursor out ref_cursor)
  is
  RF pkg_temp_fn32.ref_cursor;
  begin
    open RF for
      select x.person_code,x.person_name from t_fn_person x
               where x.map_id=pmap_id;
    p_cursor:=RF;
  end queryall;
end pkg_temp_fn32;

执行结果:

命令窗口:

 一般sql窗口:

-- 调用过程
call pkg_temp_fn31.test('000001')

 

转载于:https://www.cnblogs.com/hoaprox/p/5318836.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值