oracle - 创建 Oracle 过程

标签 oracle stored-procedures plsql ora-06512

我正在尝试创建一个过程,并且它创建时没有错误。但是,当我尝试运行它时,我会收到以下错误。请指教

SQL> begin
  2   Update_STUD_Fin ( '1011');
  3  end;
  4  /
begin
*
ERROR at line 1:
ORA-06511: PL/SQL: cursor already open
ORA-06512: at "ORAIN.UPDATE_STUD_FIN", line 3
ORA-06512: at "ORAIN.UPDATE_STUD_FIN", line 8
ORA-06512: at line 2

程序是
SQL> CREATE OR REPLACE PROCEDURE Update_STUD_Fin ( AIDY_CODE IN VARCHAR2 ) IS
  2    CURSOR PublicationC IS
  3      SELECT SGidm from SGB
  4       WHERE SGCODE_EFF ='201030';
  5  BEGIN
  6    OPEN PublicationC;
  7  
  8    FOR PublicationR IN PublicationC
  9    LOOP
 10      DBMS_OUTPUT.PUT_LINE( PublicationR.SGidm );
 11    END LOOP;
 12  
 13    close PublicationC;
 14   
 15  END;
 16  /

Procedure created.

最佳答案

您不能显式地打开游标,也不能在隐式 FOR 循环中使用它。您可以选择隐式(FOR 循环)或显式(OPEN/FETCH/CLOSE)。

关于oracle - 创建 Oracle 过程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4564689/

相关文章:

sql - 如何声明变量并在同一个 Oracle SQL 脚本中使用它?

mysql:调用过程后立即删除它

oracle - 用于 PL/SQL 开发的 IDE

java - 自动连接列表中的 PK 和 FK

oracle - 连接到Oracle 11g数据库时,Crystal Reports无法找到监听器(ORA-12541)

java.sql.SQLException : ORA-00934: group function is not allowed here oracle

MySQL 错误 #2014 - 命令不同步;你现在不能运行这个命令

sql - 数据库更新脚本中的 ALTER PROCEDURE 语法错误

oracle - ORA-00947全局声明类型时值不足

java - 连接多个数据库中的表