ORA-20000尝试使用DBMS_DDL.ALTER_COMPILE时出错

时间:2014-05-22 15:55:59

标签: oracle plsql syntax-error

我正在尝试在PL / SQL中编写一个匿名块 我的问题是我一直收到ORA-20000错误 IN DBMS_DDL.ALTER_COMPILE('PROCEDURE',NULL,'object_name'); 我已经发现它不喜欢object_name引用,因为当我添加一个特定的名称时它会运行。 我的问题是如何引用user_objects中的object_name列来选择游标中的所有object_names。 我添加了我的代码供参考。

DECLARE

cursor cur_invalid IS
SELECT object_name,status
FROM user_objects
Where object_type = 'PROCEDURE'
AND status = 'INVALID';

invalid cur_invalid%ROWTYPE;
BEGIN
OPEN cur_invalid;
LOOP
FETCH cur_invalid INTO invalid;
EXIT WHEN cur_invalid%NOTFOUND;
DBMS_DDL.ALTER_COMPILE('PROCEDURE',NULL ,'object_name');
END LOOP;
CLOSE cur_invalid;
END;

1 个答案:

答案 0 :(得分:2)

您可以使用object_name推荐invalid.object_name,它应该有效。

DECLARE 
    CURSOR cur_invalid IS 
      SELECT object_name, 
             status 
      FROM   user_objects 
      WHERE  object_type = 'PROCEDURE' 
             AND status = 'INVALID'; 
    invalid cur_invalid%ROWTYPE; 
BEGIN 
    OPEN cur_invalid; 
    LOOP 
        FETCH cur_invalid INTO invalid; 
        EXIT WHEN cur_invalid%NOTFOUND; 
        DBMS_DDL.ALTER_COMPILE('PROCEDURE', NULL, invalid.object_name); 
    END LOOP; 
    CLOSE cur_invalid; 
END; 
/