ORA-06512 CTXSYS drop user cascade

只是delete dr$index 就可以了,但是drop 后两两个表中还有残留data。

unable to drop user

aditya bisht, October 10, 2024 - 10:36 am UTC

SQL> drop user wacsmdms cascade;

drop user wacsmdms cascade

*

ERROR at line 1:

ORA-00604: error occurred at recursive SQL level 1

ORA-20000: Oracle Text error:

DRG-11338: policy WACSMDMS"."SDP_DIM_MAIL_ADDRESS_IDX does not exist

ORA-06512: at "CTXSYS.DRUE", line 186

ORA-06512: at "CTXSYS.CTX_ADM", line 280

ORA-06512: at line 1

October 10, 2024 - 5:06 pm UTC

Oracle Text metadata has become inconsistent. The index was dropped, but the meta data not updated.

You'll need to remove this information from the CTXSYS tables with statements like:

delete from ctxsys.dr$index_value where IXV_IDX_ID = ?;

delete from ctxsys.drindex_object where IXO_IDX_ID = ?; delete from ctxsys.drindex where idx_id = ?;

See MOS note 2877418.1 for more details. If you're still struggling contact Oracle support.

问题是我们无法从 sqlplus 中删除用户

。SQL> select object_name , OBJECT_TYPE,CREATED , STATUS from dba_objects

where owner='SQL_WIFGWIHDMSBUHBARKGXAYFYMT';

没有选择任何行

SQL> DROP USER SQL_WIFGWIHDMSBUHBARKGXAYFYMT CASCADE;

删除用户 SQL_WIFGWIHDMSBUHBARKGXAYFYMT 时发生级联

错误,错误位于第 1 行:

ORA-00604:递归 SQL 级别 1 发生错误

ORA-20000:Oracle Text 错误:

DRG-11338:策略 SQL_WIFGWIHDMSBUHBARKGXAYFYMT"JSON_FTS_IDX 不存在"

ORA-06512:位于"CTXSYS.DRUE",第 171 行

ORA-06512:位于"CTXSYS.CTX_ADM",第 279 行

ORA-06512:位于第 1 行

,该用户在 dba_objects 中没有任何对象,删除用户失败,错误信息

为"DRG-11338:策略 SQL_WIFGWIHDMSBUHBARKGXAYFYMT"JSON_FTS_IDX 不存在"。

诊断:

  1. 获取你的 sqlplus ospid,例如 xxxx。2

. 执行以下命令:ALTER SESSION SET EVENTS '10046 trace name context forever, level 12';

  1. 执行以下命令:DROP USER SQL_WIFGWIHDMSBUHBARKGXAYFYMT CASCADE;

  2. 检查跟踪目录 *xxxx.trc,

trc 文件包含正在运行的 SQL,包括递归 SQL。5

. 执行以下命令:ALTER SESSION SET EVENTS '10046 trace name context off';

解决方案:

发现 dr$index 表中存在 'JSON_FTS_IDX',而 dba_objects 表中不存在该项。手动删除 'JSON_FTS_IDX' 以清除路径。

Summary

Dropping a user fails with the following errors:

SQL> drop user TESTER cascade;

drop user TESTER cascade

*

ERROR at line 1:

ORA-00604: error occurred at recursive SQL level 1

ORA-20000: Oracle Text error:

DRG-11338: policy "TESTER"."DOC_INDEX" does not exist

ORA-06512: at "CTXSYS.DRUE", line 186

ORA-06512: at "CTXSYS.CTX_ADM", line 280

ORA-06512: at line 1

Solution

Delete the index metadata in the CTXSYS dictionary tables. Then drop the user.

The following statements manipulate the data dictionary and should not be executed without proper understanding of the situation.

The steps here are for experienced users only. Please take a BACKUP first as a precautionary measure.

connect / as sysdba

delete from ctxsys.dr$index_value where IXV_IDX_ID = 3500;

delete from ctxsys.dr$index_object where IXO_IDX_ID = 3500;

delete from ctxsys.dr$index where idx_id = 3500;

commit;

drop user TESTER cascade;

Cause

The index was dropped, but the CTXSYS meta-information about the index was not removed. Therefore, there is an inconsistency in the dictionary.

This is evident from the output below which shows the index exists in CTXSYS.DR$INDEX, but not in DBA_OBJECTS:

SQL> select owner, object_name, object_type, status

2 from dba_objects

3 where object_name like '%DOC_INDEX%'

4 and owner = 'TESTER';

no rows selected

SQL> select user_id from dba_users where username = 'TESTER';

USER_ID


297

SQL> select idx_id, idx_owner#, idx_name, idx_status

2 from ctxsys.dr$index

3 where idx_owner# = 297

4 and idx_name = 'DOC_INDEX';

IDX_ID IDX_OWNER# IDX_NAME IDX_STATUS


3500 297 TESTER INDEXED

相关推荐
神仙别闹3 小时前
基于Java+MySQL实现(GUI)医院管理系统
java·mysql·oracle
六月雨滴5 小时前
数据库权限管理(Privilege Management)
数据库·oracle·dba
解决问题no解决代码问题6 小时前
Quartz 1.6.5
数据库·servlet·oracle
六月雨滴11 小时前
Oracle 数据库安全审计
数据库·oracle·dba
jnrjian1 天前
expdp file 带时间戳 date
oracle
六月雨滴1 天前
存储性能监控与优化及最佳实践总结
数据库·oracle·dba
学习论之费曼学习法1 天前
Agent记忆系统:让AI拥有长期记忆能力
数据库·人工智能·oracle
arronKler1 天前
数据库设计三大范式
数据库·oracle
oradh1 天前
Oracle物理存储结构概述
数据库·oracle·物理结构·oracle基础·oracle入门·oracle物理存储结构概述
数据最前线1 天前
亡羊补牢?Oracle 计划推出月度安全补丁
数据库·oracle