gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-03 08:22:34 26 4
gpt4 key购买 nike

我试图在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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com