我在尝试更新sqlplus中的列值时遇到一个问题。
它基本上不会完成,只是挂起。我想知道有没有办法强行移除oracle中的锁?
我注意到一个名为v$locked_object的表,其中包含一个与我遇到的问题相关的对象ID。
希望我已经解释得够好了。
提前感谢您的帮助!
发布于 2012-12-13 02:06:05
这将恰好服务于您的目的:
SELECT SESSION_ID FROM DBA_DML_LOCKS WHERE NAME = <TABLE_NAME>;使用SESSION_ID查找具有以下语句的相应SERIAL#:
SELECT SID, SERIAL# FROM V$SESSION WHERE SID IN (
SELECT SESSION_ID FROM DBA_DML_LOCKS WHERE NAME = <TABLE_NAME>
);找到有问题的元组SID, SERIAL#并像这样释放它:
ALTER SYSTEM KILL SESSION 'SID, SERIAL#';发布于 2012-12-13 02:05:06
设法解决了此问题。
我查看了DBA_BLOCKERS表,得到了会话ID,然后终止了会话,锁也被移除了。
发布于 2012-12-13 01:52:51
可能,其他人已经更新了相同的表,但还没有提交。它甚至可能是你(在不同的工具或不同的会话中)。
解除锁定的最简单方法是在另一个会话中提交工作。
https://stackoverflow.com/questions/13845655
复制相似问题