阅读量:1
要查看表是否被锁定,可以使用以下方法:
使用Oracle的动态视图v$locked_object:
SELECT OBJECT_NAME, SESSION_ID, ORACLE_USERNAME FROM V$LOCKED_OBJECT WHERE OBJECT_ID = (SELECT OBJECT_ID FROM USER_OBJECTS WHERE OBJECT_NAME = 'YOUR_TABLE_NAME');
将
YOUR_TABLE_NAME
替换为你要查询的表名。使用Oracle的动态视图DBA_LOCKS:
SELECT OBJECT_NAME, SESSION_ID, ORACLE_USERNAME FROM DBA_LOCKS WHERE OBJECT_ID = (SELECT OBJECT_ID FROM USER_OBJECTS WHERE OBJECT_NAME = 'YOUR_TABLE_NAME');
将
YOUR_TABLE_NAME
替换为你要查询的表名。使用Oracle的动态视图DBA_TAB_MODIFICATIONS:
SELECT TABLE_NAME, LOCKED_MODE FROM DBA_TAB_MODIFICATIONS WHERE TABLE_NAME = 'YOUR_TABLE_NAME';
将
YOUR_TABLE_NAME
替换为你要查询的表名。
这些查询将返回锁定指定表的会话ID和用户名。如果返回结果为空,则表没有被锁定。