oracle

关注公众号 jb51net

关闭
首页 > 数据库 > oracle > Oracle查看锁表和解锁

Oracle数据库查看锁表语句和解锁的方法示例

作者:何以解忧,唯有..

在DBA的日常工作中,经常遇到为Oracle用户解锁的操作,这篇文章主要给大家介绍了关于Oracle数据库查看锁表语句和解锁的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下

一、查看锁表语句

SELECT
	sess.sid,
	sess.serial#,
	lo.oracle_username, -- 登陆账号名称
	lo.os_user_name,    -- 登录电脑名称
	ao.object_name,     -- 被锁表名
	lo.locked_mode      -- 死锁级别
FROM
	v$locked_object lo,
	dba_objects ao,
	v$session sess 
WHERE
	ao.object_id = lo.object_id 
	AND lo.session_id = sess.sid;

死锁级别:

级别描述
0none
1null 空
2Row-S 行共享(RS):共享表锁
3Row-X 行专用(RX):用于行的修改
4Share 共享锁(S):阻止其他DML操作
5S/Row-X 共享行专用(SRX):阻止其他事务操作
6exclusive 专用(X):独立访问使用

二、解锁语句

alter system kill session '68,51'; -- 分别为SID和SERIAL#号

三、查看引起锁表的Sql语句

SELECT
	A.USERNAME,
	A.MACHINE,
	A.PROGRAM,
	A.SID,
	A.SERIAL#,
	A.STATUS,
	C.PIECE,
	C.SQL_TEXT 
FROM
	V$SESSION A,
	V$SQLTEXT C 
WHERE
	A.SID IN ( SELECT DISTINCT T2.SID FROM V$LOCKED_OBJECT T1, V$SESSION T2 WHERE T1.SESSION_ID = T2.SID ) 
	AND A.SQL_ADDRESS = C.ADDRESS ( + ) 
ORDER BY
	C.PIECE;

如何避免锁表

常见问题是用户更新操作没有提交事务,所以:如果单独更新操作,需要写2个操作 SQL,一个是更新操作SQL语句,另一个是commit语句提交事务。

总结 

到此这篇关于Oracle数据库查看锁表语句和解锁的文章就介绍到这了,更多相关Oracle查看锁表和解锁内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文