oracle ORA-00604:递归SQL层1出现错误 (转)

ORA-00604:递归SQL层1出现错误 * ORA-00942:表或视图不存在
http://tech.ddvip.com/2007-05/117880760423940_2.html

  1. drop user出现问题

  报出以下错误后退出
  ORA-00604: error occurred at recursive SQL level 1
  ORA-00942: table or view does not exist .
  关于 recursive SQL 错误我们有必要做个简单说明.

  我们知道,当我们发出一条简单的命令以后
  Oracle数据库要在后台解析这条命令,并转换为Oracle数据库的一系列后台操作.
  这些后台操作统称为递归sql.
  比如create table这样一条简单的DDL命令,Oracle数据库在后台,实际上要把这个命令转换为对于obj$,tab$,col$等底层表的插入操作.Oracle所作的工作可能比我们有时候想的要复杂的多.


The reason for this problem seems to be an Upgrade for Label-Security even if it's not installed.  //Label security 没有安装,居然补丁去默认给升级?

解决方案:
shutdown immediate;
startup migrate;
alter view lbacsys.lbac$all_table_policies compile;
alter package lbacsys.lbac_events compile body;
shutdown immediate;
startup;

支持人员说这是个Bug.但是普通用户不可见.


==================================
SDO_GEOM_METADATA_TABLE表/视图不存在所致


ORA-00604 error occurred at recursive SQL level string

记得有个高手总结了关于ORA-00604/ORA-04031问题的解决:
  修改INIT.ora  添加 _db_handles_cached = 0

该错误最常见的原因是数据库文件initSID.ora中的参数OPEN_CURSORS值太小。可以修改initSID.ora文件,OPEN_CURSORS的值一般为255.修改完后,宕下ORACLE,再重新启动。
  还可以设置并启动数据库的事件跟踪功能。在initSID.ora中加上一行:event = "00604 trace name errorstack"

  造成ORA-604错误的其它原因可能有:
  - initSID.ora中,参数DC_FREE_EXTENTS或ROW_CACHE_ENQUEUES太低。可以根据操作系统和数据库的情况,适当增加这两个参数的值,宕下并重新启动ORACLE.
  - 运行超出空间(伴随ORA-1547错误)。这时,要对表空间添加新文件,即增加表空间的大小。
  - 达到了MAX_EXTENTS(伴随ORA-1556错误)。如果这样,就要修改表,允许更多的扩展。请从技术手册中查找MAX_EXTENTS的最大值。如果已经达到了最大值,必须用compress extents选项,把表卸出(export),再导入(import)数据库中。

_+++++++++++++++++++++++
我用过此方法不过是在9.2.0.1升级到9.2.0.4,
方法:
后来也是以sysdba身份运行catexp.sql,后再以sysdba身份运行catpatch.sql
shutdown immediate;
startup migrate;
alter view lbacsys.lbac$all_table_policies compile;
alter package lbacsys.lbac_events compile body;
shutdown immediate;
startup;
祥细请看http://www.dbanotes.net/Oracle/a_case_about_export.htm

你可能感兴趣的:(oracle ORA-00604:递归SQL层1出现错误 (转))