oracle存储过程 用游标的几种方法

-- 使用游标的四种方法,感觉for循环的最简单

create or replace procedure exportData is
begin
  declare
    cursor depart is
      select * from t_department;
    v_id       number;
    v_name     varchar2(500);
    v_parentId number;
  
  begin
    /*用while 循环,将游标值放入变量中
      之前要声明变量
    
    
    open depart;
     
       fetch depart
         into v_id, v_name, v_parentId;
     
       while depart%found loop
         insert into t_depart values (v_id, v_name, v_parentId);
       
         fetch depart
           into v_id, v_name, v_parentId;
       
       end loop;
       close depart;*/
  
    /*  
        for循环比较简单,比while少了很多行,不用判断指针是否到末尾了
          
    for dep in depart
      loop
      insert into t_depart values(dep.id,dep.name,dep.parentId);
      end loop;  */
  
    /*  if…then的形式,和while相似 
     
     open depart;
    
      fetch depart
        into v_id, v_name, v_parentId;
    
      loop
      if depart%found then
        insert into t_depart values (v_id, v_name, v_parentId);
      
        fetch depart
          into v_id, v_name, v_parentId;   
      else
      exit;
      end if;
      end loop;
      close depart;
    */
       
    open depart;
    loop
                             ---exit when 的形式
      fetch depart
        into v_id, v_name, v_parentId;
      exit when depart%notfound;
    
      insert into t_depart values (v_id, v_name, v_parentId);
    
    end loop;
    close depart;
  
  end;

end exportData;

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值