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

标签 oracle plsql syntax-error

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

相关文章:

java - JPQL 中有这样的 CASE 表达式吗?

oracle - JPA根据请求参数更改实体表名称

sql - Oracle 将多行合并为一个具有不同标题的行

c# - 需要创建一个在目标列中插入数据的 SSIS 包

class - typescript : unexpected reserved word in PHPStorm

compiler-errors - 命令代码中的语法错误

sql - 在 Oracle SQL 中连接

SQL错误 "ORA-01722: invalid number"

SQL在特定日期选择重复项

sql-server - '('附近的语法不正确。期望ID-不知道如何解决此问题