一、查看锁表语句
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;
死锁级别:文章来源地址https://www.toymoban.com/news/detail-566091.html
级别 | 描述 |
---|---|
0 | none |
1 | null 空 |
2 | Row-S 行共享(RS):共享表锁 |
3 | Row-X 行专用(RX):用于行的修改 |
4 | Share 共享锁(S):阻止其他DML操作 |
5 | S/Row-X 共享行专用(SRX):阻止其他事务操作 |
6 | exclusive 专用(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;
文章来源:https://www.toymoban.com/news/detail-566091.html
到了这里,关于Oracle 数据库查看锁表的语句和解锁的方法的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!