深入探讨:Oracle中如何查询正锁表的用户以及释放被锁的表的方法
2013-05-30 00:00
633 查看
可在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
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
相关文章推荐
- 深入探讨:Oracle中如何查询正锁表的用户以及释放被锁的表的方法
- Oracle中查询正锁表的用户及释放被锁的表的方法
- 如何oracle 某一用户授予查询另一个用户某张表的权限,以及更新另一用户表中某些字段
- Oracle中查询正锁表的用户及释放被锁的表的方法
- Oracle中查询正锁表的用户及释放被锁的表的方法
- Oracle中查询正锁表的用户及释放被锁的表的方法
- Oracle 10g如何对用户姓名,按首字母排序、查询
- Oracle数据如何查看有多少用户连接以及如何kill某个连接
- ORACLE 如何查询被锁定表及如何解锁释放session
- 将oracle查询权限赋予另一用户的方法
- ORACLE 如何查询被锁定表及如何解锁释放session
- oracle 分页查询的方法,以及page实体类
- oracle 中的ROW_NUMBER() OVER() 的用法以及如何把空值转化指定值——记一次查询
- Oracle中如何删除某个用户下的所有数据的方法
- 深入C中常用的三种排序方法总结以及探讨分析
- 如何查询Oracle中用户所有信息
- 如何在oracle中查询所有用户表的表名、主键名称、索引、外键等
- Oracle11完全卸载方法 deinstall.bat如何用以及如何删除oracle注册表
- 解析oracle对select加锁的方法以及锁的查询
- 如何用eclipse将数据库oracle数据相连接,实现查询数据库中的信息以及更改添加表中内容