Oracle:ORA-00054 资源正忙 – 锁表的解决方法
常用MySQL的朋友突然跑来用oracle可能会遇到这样的报错
- 问题描述
ORA-00054: 资源正忙, 但指定以 NOWAIT 方式获取资源, 或者超时失效 发生异常。
原因:其他Session已经对目标表做了操作,且未提交操作,导致锁表,新的Session无法再对表进行DDL操作。 - 解决方法
Plan-A:等待原session执行完对表的操作,或commit对表的操作。
Plan-B:关闭原会话,如果是由于操作失误导致的锁表,建议使用Plan-B。
--查询被锁的会话ID
select session_id from v$locked_object;
--查询结果:SESSION_ID---192
--查询上面会话的详细信息:
SELECT sid, serial#, username, osuser FROM v$session where sid = 9;
--查询结果:serial---53961
--将上面锁定的会话关闭,格式为'sid,serial':
ALTER SYSTEM KILL SESSION '192,53961';