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

相关推荐
小脑斧1232 小时前
Oracle客户端11g 18c 19c,亲测可用
oracle
小脑斧1233 小时前
Oracle透明网关,亲测好用
oracle
whn19774 小时前
虚拟机搭建达梦dsc第二版
数据库·oracle
猫的玖月5 小时前
SQL语法简介
数据库·sql·oracle
TO_ZRG6 小时前
Android Content Provider 基础
android·jvm·oracle
小脑斧1236 小时前
DBExport2.51 Oracle数据库查询与Excel数据导出工具
数据库·oracle·excel
摇滚侠7 小时前
Oracle 标准结构 一个项目 一个用户 一个表空间
数据库·oracle
FinTech老王7 小时前
突破批处理瓶颈:KingbaseES并行DML技术如何榨干多核CPU性能
数据库·安全·oracle
Irene19911 天前
SQL查询优化:NOT EXISTS与LEFT JOIN性能对比
oracle·哈希算法
2301_800976931 天前
数据库的基本操作
数据库·sql·oracle