问题描述
ORA-00054: 资源正忙, 但指定以 NOWAIT 方式获取资源, 或者超时失效 发生异常
原因:其他Session已经对目标表做了操作,且未提交操作,导致锁表,新的Session无法再对表进行DDL操作。
解决方法
Plan-A:等待原session执行完对表的操作,或commit对表的操作。
Plan-B:关闭原会话。
--查询被锁的会话ID
select session_id from v$locked_object;
--查询结果:SESSION_ID-------9
--查询上面会话的详细信息:
SELECT sid, serial#, username, osuser FROM v$session where sid = 9;
--查询结果:serial#------99
--将上面锁定的会话关闭:
ALTER SYSTEM KILL SESSION '9,99';
--语句2
select t2.username oracle用户名,
t2.sid sid进程号,
t2.serial# serial#序列号,
t3.object_name 表名,
t2.OSUSER 操作系统用户名,
t2.MACHINE 机器名,
t2.PROGRAM 操作工具,
t2.LOGON_TIME 登陆时间,
t1.LOCKED_MODE 锁表模式
from v$locked_object t1, v$session t2, dba_objects t3
where t1.session_id = t2.sid
and t1.object_id = t3.object_id;
参考资料:
1、https://blog.csdn.net/wlf2601567/article/details/82623705 20210420
2、https://blog.csdn.net/weixin_43790613/article/details/109694739 20210420