Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/google-sheets/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Stored procedures 未遵守存储过程_Stored Procedures_Plsql_Plsqldeveloper - Fatal编程技术网

Stored procedures 未遵守存储过程

Stored procedures 未遵守存储过程,stored-procedures,plsql,plsqldeveloper,Stored Procedures,Plsql,Plsqldeveloper,我正在尝试在Oracle pl/sql中运行以下存储过程。我试图使用表1和表2从连接游标中获取数据,并更新表3中的输出,但是它在declare附近给了我compliation错误。查询工作正常 create or replace PACKAGE BODY PKG_LOAD_BY_ROWID AS PROCEDURE PRC_LOAD_BY_ROWID AS DECLARE N1 NUMBER; VAR_ROWID_OBJECT VARCHAR2(255); VAR_PRTY_FK VARCHAR

我正在尝试在Oracle pl/sql中运行以下存储过程。我试图使用表1和表2从连接游标中获取数据,并更新表3中的输出,但是它在declare附近给了我compliation错误。查询工作正常

create or replace PACKAGE BODY PKG_LOAD_BY_ROWID AS
PROCEDURE PRC_LOAD_BY_ROWID AS
DECLARE
N1 NUMBER;
VAR_ROWID_OBJECT VARCHAR2(255);
VAR_PRTY_FK VARCHAR2(255);
V_OUT_ERROR_MSG VARCHAR2(1000);
v_out_return_code number;

CURSOR C1 IS
SELECT PX.ROWID_OBJECT , A.PRTY_FK 
FROM TABLE_1 PX
INNER JOIN
TABLE_2 A
ON
substr(PX.PKEY_SRC_OBJECT,8,INSTR(PX.PKEY_SRC_OBJECT,'|')+8)=A.ALT_ID_VAL
WHERE A.ALT_ID_TYP='DUMMY1' AND PX.ROWID_SYSTEM='SRC';
BEGIN
SELECT COUNT(1) INTO N1  FROM TABLE_3 WHERE SRC_SYSTEM='SRC2' AND ROWID_OBJECT IS NULL;
BEGIN
OPEN C1;
FOR i in 1..n1
LOOP
FETCH C1 INTO VAR_ROWID_OBJECT, VAR_PRTY_FK;
UPDATE TABLE3 SET ROWID_OBJECT= VAR_ROWID_OBJECT WHERE
SRC_KEY=VAR_PRTY_FK;
COMMIT;
END LOOP;
CLOSE C1;
v_out_return_code :=0;
DBMS_OUTPUT.put_line('Rowid_object updated successfully for VVA');
EXCEPTION
when others then
 out_error_msg := 'Updation Error';
 DBMS_OUTPUT.put_line (out_error_msg);
END;
END;
END PKG_LOAD_BY_ROWID;
但是,我发现编译错误:

Error(2,1): PLS-00103: Encountered the symbol "DECLARE" when expecting one of the following:     begin function pragma procedure subtype type current cursor delete    exists prior external language

Oracle版本:

过程不需要Declare关键字,它仅用于匿名块。只需删除declare并尝试它