Oracle删除用户出错的解决

来源:互联网 发布:淘宝发布茶叶添加型号 编辑:程序博客网 时间:2024/05/16 14:34
 

问题描述:

在执行

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;

就可以正常删除用户了