在执行
drop user AAA;
删除用户时,出现错误:
ORA-00604:递归SQL层1出现错误
ORA-00942:表或视图不存在
解决办法:
第一步,设置sql_trace=true,以便在运行sql语句后在D:oracleadminORADB00udump下生成跟踪文件。
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:oracleora92rdbmsadmincatqueue.sql即可。执行
@D:oracleora92rdbmsadmincatqueue.sql
后,再执行
desc system.AQ$_INTERNET_AGENT_PRIVS
可以看到该表的结构。
最后再执行删除用户的操作:
drop user AAA;
就可以正常删除用户了
[@more@]来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/22934571/viewspace-1041955/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/22934571/viewspace-1041955/
本文介绍了解决在Oracle数据库中删除用户时遇到的ORA-00604和ORA-00942错误的方法。通过启用SQL跟踪、检查跟踪文件并创建缺失的表AQ$_INTERNET_AGENT_PRIVS,最终成功删除用户。
5921

被折叠的 条评论
为什么被折叠?



