如何捕获PL/SQL脚本中的所有异常?

Her*_*des 4 plsql exception oracle-sqldeveloper

目前我正在编写一个带有错误处理的更新脚本。该脚本的一部分包含对可能不存在的表的调用。所以我想捕获异常。然而,当在SQL Developer中运行脚本时,它似乎没有捕获异常。

脚本(简化):

BEGIN
    SELECT VersionNumber
    FROM DbVersion;
  EXCEPTION
    WHEN OTHERS THEN
        DBMS_OUTPUT.put_line(SQLCODE);
END;
Run Code Online (Sandbox Code Playgroud)

SQL 开发人员脚本输出:

Error starting at line 2 in command:
BEGIN
    SELECT VersionNumber
    FROM DbVersion;
  EXCEPTION
    WHEN OTHERS THEN
        DBMS_OUTPUT.put_line(SQLCODE);
END;
Error report:
ORA-06550: line 3, column 10:
PL/SQL: ORA-00942: table or view does not exist
ORA-06550: line 2, column 5:
PL/SQL: SQL Statement ignored
06550. 00000 -  "line %s, column %s:\n%s"
*Cause:    Usually a PL/SQL compilation error.
*Action:
Run Code Online (Sandbox Code Playgroud)

为什么它不简单地显示错误代码?谢谢!

小智 5

如果您使用不存在的表 - 这是语法错误 - plsql 块无效,并且无法运行。异常处理在块运行时起作用。

如果您需要使用可能不存在的表,可以使用动态sql(立即执行“select ... from non_existing_table”)以避免编译错误。

或者在 all_tables 视图中检查表是否存在。