开发者

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

目录
  • 一、查看锁表语句
  • 二、解锁语句
  • 三、查看引起锁表的Sql语句
  • 总结 

一、查看锁表语句

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 loKXighktLuC.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 FRO编程客栈M V$LOCKED_OBJECT T1, V$SESSION T2 WHERE T1.SESSION_ID = T2.SID ) 
	AND A.SQL_ADDRESS = C.ADDRESS ( + ) 
ORDER BY
	C.PIECE;

如何避免锁表

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

总结 

到此这篇关于Oracle数据库查看锁表语python句和解锁的文章就介绍到这了,更多相关Oracle查看锁表和解锁内容请搜索编程客栈(www.devze.com)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程客栈(www.devze.com)!

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新数据库

数据库排行榜