欢迎投稿

今日深度:

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

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 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查看锁表和解锁内容请搜索PHP之友以前的文章或继续浏览下面的相关文章希望大家以后多多支持PHP之友!

您可能感兴趣的文章:
  • oracle查询锁表与解锁情况提供解决方案
  • ORACLE 如何查询被锁定表及如何解锁释放session
  • 深入探讨:Oracle中如何查询正锁表的用户以及释放被锁的表的方法
  • 查看Oracle中是否有锁表的sql
  • oracle查看被锁的表和被锁的进程以及杀掉这个进程
  • oracle查询锁表及解锁,修改表字段名与复制表结构和数据的方法
  • Oracle数据库表被锁如何查询和解锁详解
  • oracle数据库查看锁表的sql语句整理
  • Oracle查锁表的实现(史上最全)

www.htsjk.Com true http://www.htsjk.com/oracle/47584.html NewsArticle Oracle数据库查看锁表语句和解锁的方法示例, 目录 一、查看锁表语句 二、解锁语句 三、查看引起锁表的Sql语句 总结 一、查看锁表语句 SELECTsess.sid,sess.serial#,lo.oracle_username, -- 登陆账号...
评论暂时关闭