欢迎来到代码驿站!

Oracle

当前位置:首页 > 数据库 > Oracle

oracle查询锁表与解锁情况提供解决方案

时间:2021-08-07 08:44:41|栏目:Oracle|点击:

如果发生了锁等待,我们可能更想知道是谁锁了表而引起谁的等待
以下的语句可以查询到谁锁了表:

复制代码 代码如下:

SELECT /*+ rule */ s.username,
decode(l.type,'TM','TABLE LOCK',
'TX','ROW LOCK',
NULL) LOCK_LEVEL,
o.owner,o.object_name,o.object_type,
s.sid,s.serial#,s.terminal,s.machine,s.program,s.osuser
FROM v$session s,v$lock l,dba_objects o
WHERE l.sid = s.sid
AND l.id1 = o.object_id(+)
AND s.username is NOT NULL

以下的语句可以查询到谁在等待:
复制代码 代码如下:

SELECT /*+ rule */ lpad(' ',decode(l.xidusn ,0,3,0))||l.oracle_username User_name, o.owner,o.object_name,o.object_type,s.sid,s.serial#
FROM v$locked_object l,dba_objects o,v$session s
WHERE l.object_id=o.object_id
AND l.session_id=s.sid
ORDER BY o.object_id,xidusn DESC

解锁命令:
复制代码 代码如下:

alter system kill session 'sid,serial#'

1).
复制代码 代码如下:

select LOCK_INFO.OWNER || '.' || LOCK_INFO.OBJ_NAME as "已?i物件名?Q", --物件名?Q(已?被?i住)
LOCK_INFO.SUBOBJ_NAME as "已?i子物件名?Q", -- 子物件名?Q(已?被?i住)
SESS_INFO.MACHINE as "?C器名?Q", -- ?C器名?Q
LOCK_INFO.SESSION_ID as "???ID", -- ???SESSION_ID
SESS_INFO.SERIAL# as "???SERIAL#", -- ???SERIAL#
SESS_INFO.SPID as "OS系?y的SPID", -- OS系?y的SPID
(SELECT INSTANCE_NAME FROM V$INSTANCE) "??例名SID", --??例名SID
LOCK_INFO.ORA_USERNAME as "ORACLE用??", -- ORACLE系?y用?裘??Q
LOCK_INFO.OS_USERNAME as "OS用??", -- 作?I系?y用?裘??Q
LOCK_INFO.PROCESS as "?M程??", -- ?M程??
LOCK_INFO.OBJ_ID as "?ο?ID", -- ?ο?ID
LOCK_INFO.OBJ_TYPE as "?ο箢?型", -- ?ο箢?型
SESS_INFO.LOGON_TIME as "登??r?g", -- 登??r?g
SESS_INFO.PROGRAM as "程式名?Q", -- 程式名?Q
SESS_INFO.STATUS as "?????B", -- ?????B
SESS_INFO.LOCKWAIT as "等待?i", -- 等待?i
SESS_INFO.ACTION as "?幼?", -- ?幼?
SESS_INFO.CLIENT_INFO as "客?糍Y?" -- 客?糍Y?
from (select obj.OWNER as OWNER,
obj.OBJECT_NAME as OBJ_NAME,
obj.SUBOBJECT_NAME as SUBOBJ_NAME,
obj.OBJECT_ID as OBJ_ID,
obj.OBJECT_TYPE as OBJ_TYPE,
lock_obj.SESSION_ID as SESSION_ID,
lock_obj.ORACLE_USERNAME as ORA_USERNAME,
lock_obj.OS_USER_NAME as OS_USERNAME,
lock_obj.PROCESS as PROCESS
from (select *
from all_objects
where object_id in (select object_id from v$locked_object)) obj,
v$locked_object lock_obj
where obj.object_id = lock_obj.object_id) LOCK_INFO,
(select SID,
SERIAL#,
LOCKWAIT,
STATUS,
(select spid from v$process where addr = a.paddr) spid,
PROGRAM,
ACTION,
CLIENT_INFO,
LOGON_TIME,
MACHINE
from v$session a) SESS_INFO
where LOCK_INFO.SESSION_ID = SESS_INFO.SID
order by LOCK_INFO.SESSION_ID;

2).
复制代码 代码如下:

select sql_text
from v$sqltext
where address in (select sql_address from v$session where sid = &sid)
order by piece;

3).
复制代码 代码如下:

ALTER SYSTEM KILL SESSION '???ID,???SERIAL#';

4).
kill -9 OS系?y的SPID

上一篇:通过sql准确查出一天数据的方法

栏    目:Oracle

下一篇:plsql与tsql的语法不同

本文标题:oracle查询锁表与解锁情况提供解决方案

本文地址:http://www.codeinn.net/misctech/165005.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有