我试图在PL/SQL中写一个匿名块
我的问题是我不断收到ORA-20000错误
在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;
最佳答案
您可以使用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;
/
关于oracle - 尝试使用DBMS_DDL.ALTER_COMPILE时出现ORA-20000错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23811781/