存储过程定义多个游标多个begin

Posted 小白工作室

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了存储过程定义多个游标多个begin相关的知识,希望对你有一定的参考价值。

1、直接定义多个显示游标 
CREATE OR REPLACE PROCEDURE ACC.DBP_REALCITYTRAFFICCNT IS 
CURSOR cur1 IS SELECT 。。。 --第一个游标 

CURSOR cur2 IS SELECT 。。。 --第二个游标 

BEGIN 


--调用cur1 
BEGIN 
OPEN cur1 ;   
  LOOP 
  FETCH cur1 INTO 。。。 
  EXIT WHEN cur1%NOTFOUND;   
  ...业务逻辑 
  COMMIT; 

  END LOOP; 
  CLOSE cur1; 

END; 

--调用cur2 
BEGIN 
  OPEN cur2 ;   
  LOOP 
  FETCH cur2 INTO 。。。 
  EXIT WHEN cur2%NOTFOUND;   
  ...业务逻辑 
  COMMIT; 

  END LOOP; 
  CLOSE cur2; 

end; 
END DBP_REALCITYTRAFFICCNT; 


-------------------------- 
2、通过定义ref游标来实现 
TYPE refcur_t IS REF CURSOR; --声明REF游标类型 

cur1 refcur_t; --声明第一个游标REF游标类型的变量 

cur2 refcur_t; --声明第二个游标REF游标类型的变量 

BEGIN 


--调用cur1 
BEGIN 
OPEN cur1 ;   
  LOOP 
  FETCH cur1 INTO 。。。 
  EXIT WHEN cur1%NOTFOUND;   
  ...业务逻辑 
  COMMIT; 

  END LOOP; 
  CLOSE cur1; 

END; 

--调用cur2 
BEGIN 
  OPEN cur2 ;   
  LOOP 
  FETCH cur2 INTO 。。。 
  EXIT WHEN cur2%NOTFOUND;   
  ...业务逻辑 
  COMMIT; 

  END LOOP; 
  CLOSE cur2; 

end; 
END DBP_REALCITYTRAFFICCNT;

以上是关于存储过程定义多个游标多个begin的主要内容,如果未能解决你的问题,请参考以下文章

如何使用c#执行返回多个游标的oracle存储过程

oracle存储过程的使用

MySQL存储过程,处理多个游标和查询结果

MySql存储过程和游标的使用

mysql中的存储过程和游标

oracle存储过程怎么写循环