当先锋百科网

首页 1 2 3 4 5 6 7

问题描述:

在执行

drop user AAA;

删除用户时,出现错误:

ORA-00604:递归SQL层1出现错误

ORA-00942:表或视图不存在

解决办法:

第一步,设置sql_trace=true,以便在运行sql语句后在D:\oracle\admin\ORADB00\udump下生成跟踪文件。

alter session sql_trace=true;

第二步,运行

drop user AAA;

出错后,查看最新的跟踪文件,可以看到最后几行中显示在执行

delete from system.AQ$_INTERNET_AGENT_PRIVS where ....

时出现的ORA-00942:表或视图不存在这个错误。

执行

desc system.AQ$_INTERNET_AGENT_PRIVS

也显示表不存在

说明表AQ$_INTERNET_AGENT_PRIVS不存在,只需创建它即可。

第三步,上网查找表AQ$_INTERNET_AGENT_PRIVS的创建,发现只要运行D:\oracle\ora92\rdbms\admin\catqueue.sql即可。执行

@D:\oracle\ora92\rdbms\admin\catqueue.sql

后,再执行

desc system.AQ$_INTERNET_AGENT_PRIVS

可以看到该表的结构。

最后再执行删除用户的操作:

drop user AAA;

就可以正常删除用户了