[Oracle]高效的PL/SQL程序设计(六)--%ROWTYPE的使用

 

 在PL/SQL程序中, 我们会遇到需要先从一个结果集中取出若干记录, 然后对每一条记录进行处理的情况, 最理想的做法是在一条SQL语句中完成, 但有时候因为需求的关系所以不一定能实现, 所以我们通常会定义几个变量, 然后对结果集做循环, 赋值给变量. 最典型的就是select XX into XX。我们也可以用定义一个记录%rowtype的方法, 减少不必要的代码量, 还能避免由于表中字段的变更造成的错误。示例如下:

创建测试表:

create   table  t1  as   select   *   from  user_tables

创建PACKAGE HEAD:

create   or   replace  package Type_demo  is

 
procedure  process1(p_record  in  t1 % rowtype);
 
procedure  process_data(p_inputs  in   varchar2 );

end  Type_demo;

创建PACKAGE BODY:

create   or   replace  package body Type_demo  is

procedure  process1(p_record  in  t1 % rowtype)
as  
begin       
       dbms_output.put_line(p_record.tablespace_name);
end ;

procedure  process_data(p_inputs  in   varchar2 )
as
begin
       
for  x  in ( select   *   from  t1  where  table_name  like  p_inputs)
       loop
           process1(x);
       
end  loop;
end ;

end  Type_demo;

上面的例子得到的是整个表的记录类型, 如果想要得到某几个列的记录类型, 可以按照如下做法:

create   or   replace  package Type_demo  is

 
cursor  template_cursor
    
is   select  table_name,tablespace_name  from  t1;

 
-- type rc is ref cursor;

 
procedure  process2(p_record  in  template_cursor % rowtype);
 
procedure  process_data(p_cname  in   varchar2 ,p_inputs  in   varchar2 );
end  Type_demo;

 

create   or   replace  package body Type_demo  is

procedure  process2(p_record  in  template_cursor % rowtype)
as  
begin   
       dbms_output.put_line(p_record.tablespace_name);
end ;

procedure  process_data(p_cname  in   varchar2 ,p_inputs  in   varchar2 )
as
  
-- l_cursor rc;
  l_cursor sys_refcursor;
  l_rec template_cursor
% rowtype;
begin
     
open  l_cursor
     
for
     
' select table_name,tablespace_name from t1 where  ' ||  p_cname  || '  like :x '  using p_inputs;
     loop
         
fetch  l_cursor  into  l_rec;
         
exit   when  l_cursor % notfound;
         process2(l_rec);
     
end  loop;
end ;

end  Type_demo;

注:还有一个获得列的数据类型%TYPE

l_tablename t1.tablename % type;
   select XX into l_tablename from t1 where...
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值