数据库添加DBLink后,很容易出现一个问题:
ORA-02049:超时:分布式事务处理等待锁
ORA-02063:紧接着line(起自ODS_LINK)
在这里插入图片描述

问题原因分析:第一次执行操作后出错,数据库没有提交或回退,未关闭原有数据库窗口,重新打开新窗口执行数据插入操作,报ORA-02049错误。
解决办法:
数据库登陆管理员账号查看
1、查看死锁进程

SELECT S.USERNAME,
       DECODE(L.TYPE, 'TM', 'TABLE LOCK', 'TX', 'ROW LOCK', NULL) LOCK_LEVEL,
       O.OWNER,
       O.OBJECT_NAME,
       O.OBJECT_TYPE,
       S.SID,
       S.SERIAL#,
       S.TERMINAL,
       S.MACHINE,
       S.PROGRAM,
       S.OSUSER
  FROM V$SESSION S, V$LOCK L, DBA_OBJECTS O
 WHERE L.SID = S.SID
   AND L.ID1 = O.OBJECT_ID(+)
   AND S.USERNAME IS NOT NULL;

2、找出LOCK_LEVEL列为TABLE LOCK或者ROW LOCK的SID和SERIAL#,然后将死锁进程杀掉
ALTER SYSTEM KILL SESSION ‘SID,SERIAL#’;
例:

ALTER SYSTEM KILL SESSION '1423,21679';

重新执行数据插入操作时,一切正常。

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐