我正在尝试在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;
答案 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;
/