问题描述:
在执行
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;
就可以正常删除用户了