欢迎来到代码驿站!

Oracle

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

查看Oracle中是否有锁表的sql

时间:2021-06-17 09:17:42|栏目:Oracle|点击:
1、查看是否有锁表的sql
复制代码 代码如下:

select 'blocker('||lb.sid||':'||sb.username||')-sql:'|| qb.sql_text blockers,
'waiter ('||lw.sid||':'||sw.username||')-sql:'|| qw.sql_text waiters
from v$lock lb,
v$lock lw,
v$session sb,
v$session sw,
v$sql qb,
v$sql qw
where lb.sid=sb.sid
and lw.sid=sw.sid
and sb.prev_sql_addr=qb.address
and sw.sql_address=qw.address
and lb.id1=lw.id1
and sw.lockwait is not null
and sb.lockwait is null
and lb.block=1 ;

2、查看被锁的表
复制代码 代码如下:

select p.spid,a.serial#,c.object_name,b.session_id,b.oracle_username,b.os_user_name
from v$process p,v$session a, v$locked_object b,all_objects c
where p.addr=a.paddr and a.process=b.process and c.object_id=b.object_id ;

3、查看那个用户那个进程造成死锁,锁的级别
复制代码 代码如下:

select b.owner,b.object_name,l.session_id,l.locked_mode fromv$locked_object l, dba_objects

4、查看连接的进程
复制代码 代码如下:

SELECT sid, serial#, username, osuser FROMv$session;

5、查看是哪个session引起的
复制代码 代码如下:

select b.username,b.sid,b.serial#,logon_time
from v$locked_object a,v$session b
where a.session_id = b.sid order by b.logon_time;

6、杀掉进程
复制代码 代码如下:

alter system kill session 'sid,serial#';

sid是第5步查询出的sid和serid

上一篇:Oracle批量执行sql语句之禁用所有表的外键

栏    目:Oracle

下一篇:oracle安装出现乱码等相关问题

本文标题:查看Oracle中是否有锁表的sql

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

推荐教程

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

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

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

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

Copyright © 2020 代码驿站 版权所有