首页 Oracle 深入探讨:Oracle中如何查询正锁表的用户以及释放被锁的表的方法

深入探讨:Oracle中如何查询正锁表的用户以及释放被锁的表的方法

本篇文章是对Oracle中查询正锁表的用户以及释放被锁的表的方法进行了详细的分析介绍,需要的朋友参考下

可在PL/SQL中用如下SQL语句来查询当前数据库中哪些表被锁住了,并且是哪些用户来锁的这些表:


SELECT

A.OWNER,–OBJECT所属用户
A.OBJECT_NAME,–OBJECT名称(表名)
B.XIDUSN,
B.XIDSLOT,
B.XIDSQN,
B.SESSION_ID,–锁表用户的session
B.ORACLE_USERNAME,–锁表用户的Oracle用户名
B.OS_USER_NAME,–锁表用户的操作系统登陆用户名
B.PROCESS,
B.LOCKED_MODE,
C.MACHINE,–锁表用户的计算机名称(例如:WORKGROUP\UserName)
C.STATUS,–锁表状态
C.SERVER,
C.SID,
C.SERIAL#,
C.PROGRAM –锁表用户所用的数据库管理工具(例如:ob9.exe)

FROM

ALL_OBJECTS A,
V$LOCKED_OBJECT B,
SYS.GV_$SESSION C

WHERE

A.OBJECT_ID = B.OBJECT_ID
AND B.PROCESS = C.PROCESS
ORDER BY 1,2 同时可用如下命令来kill掉当前锁表的项:


alter system kill session ‘sid,serial#’
–例如:alter system kill session ‘57,10325

本文来自网络,不代表青岛站长网立场。转载请注明出处: https://www.0532zz.com/html/shujuku/oracle/20201019/11355.html
上一篇
下一篇

作者: dawei

【声明】:青岛站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。

为您推荐

返回顶部