视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
Dropgoldengate用户时报ORA-00604ORA-20782ORA-06512问题解决
2020-11-09 14:26:05 责编:小采
文档


Drop goldengate用户时报ORA-00604 ORA-20782 ORA-06512问题解决

1、问题现象
SQL> drop user goldengate cascade;

Drop goldengate用户时,报ORA-00604 ORA-20782 ORA-06512错误,具体报错内容如下:

drop user goldengate cascade

*

ERROR at line 1:

ORA-00604: error occurred at recursive SQL level 2

ORA-20782: Oracle GoldenGate DDL Replication Error: Code :ORA-20782: Cannot

DROP object used in Oracle GoldenGate replication while trigger is enabled.

Consult Oracle GoldenGate documentation and/or call Oracle GoldenGate Technical

Support if you wish to do so., error stack: ORA-06512: at line 261

ORA-06512: at line 1111

2、原因分析
由于在安装OGG时,配置并开启了DDL捕获功能,而OGG的DDL捕获,是依赖DDL触发器实现的,,DDL处于enabled状态,drop goldengate user操作也属于DDL操作,所以产生ORA-00604 ORA-20782错误

3、验证DDL触发器状态
SQL> set linesize 999

SQL>select owner,trigger_name,trigger_type,triggering_event,status from dba_triggers where trigger_name like 'GGS%';

OWNER TRIGGER_NAME TRIGGER_TYPE TRIGGERING_EVENT STATUS

----------------- --------------------------- ----------------------- ----------------------------- ---------

SYS GGS_DDL_TRIGGER_BEFORE BEFORE EVENT DDL ENABLED

4、删除触发器
SQL>drop trigger sys.GGS_DDL_TRIGGER_BEFORE

5、再次尝试删除用户
SQL> drop user goldengate cascade;

drop user goldengate cascade

*

ERROR at line 1:

ORA-00604: error occurred at recursive SQL level 1

ORA-14452: attempt to create, alter or drop an index on temporary table already in use

再次报错,但是报错内容发生了改变

报错意思为:试图创建,更改或删除正在使用的临时表中的索引

6、找出正在使用临时表的会话,并killsession
SQL>select 'alter system kill session '''||sid||','||serial#||'''' from v$session where sid in

(select sid from v$lock where id1 in

(select object_id from dba_objects where object_name in (select table_name from dba_tables where owner='GOLDENGATE')));

7、再次删除用户
SQL> drop user goldengate cascade;

User dropped.

删除成功。

本文永久更新链接地址:

下载本文
显示全文
专题