oracle 锁表解决办法

发布时间:2023年12月18日

相关表介绍

  • V$LOCKED_OBJECT(记录锁信息的表)
  • v$session(记录会话信息的表)
  • v$sql(记录 sql 执行的表)
  • dba_objects(用来管理对象,表、库等等)
查询锁表的 SID
select b.SID,b.SERIAL#,b.USERNAME,b.STATUS,b.MACHINE,b.LOCKWAIT,b.PROGRAM from V$SESSION b where b.SID in (select a.SESSION_ID from V$LOCKED_OBJECT a);

  • SID:会话 id
  • USERNAME:死锁语句所用的数据库用户
  • STATUS:状态,active 表示死锁
  • MACHINE:死锁语句所在的机器
  • LOCKWAIT:死锁的状态,如果有内容表示被死锁
  • PROGRAM:产生死锁的语句主要来自哪个应用程序
查看锁表执行语句
用sid 查询单个
select a.SQL_TEXT
from V$SQL a
where a.HASH_VALUE in (select b.SQL_HASH_VALUE from V$SESSION b where b.SID = '358');
查询所有加锁的 sql
select a.SQL_TEXT
from V$SQL a
where a.HASH_VALUE in (select b.SQL_HASH_VALUE
                       from V$SESSION b
                       where b.SID in (select c.SESSION_ID
                                       from V$LOCKED_OBJECT c));
查询未提交事务的 sql
select s.SID,
       s.SERIAL#,
       s.USERNAME,
       s.LOCKWAIT,
       s.PROGRAM,
       s.MACHINE,
       s.STATUS,
       TO_CHAR(s.LOGON_TIME, 'yyyy-mm-dd hh24:mi:ss')                                              LOGON_TIME,
       TO_CHAR(t.START_DATE, 'yyyy-mm-dd hh24:mi:ss')                                              START_DATE,
       (select q.SQL_TEXT from V$SQL q where q.LAST_ACTIVE_TIME = t.START_DATE and rownum <= 1) as sql
from V$SESSION s,
     V$TRANSACTION t
where s.SADDR = t.SES_ADDR
查询锁表的会话 id、及sql 脚本
-- 查询锁表会话ID、sql脚本
select s.SID        会话ID,
       s.SERIAL#,
       s.USERNAME   数据库用户名,
       s.PROGRAM    执行程序,
       s.MACHINE    死锁语句所在机器,
       s.STATUS     锁状态,
       s.LOCKWAIT   死锁描述,
       s.MODULE     会话客户端,
       s.LOGON_TIME 加锁时间,
       q.SQL_TEXT   脚本详情
from V$SESSION s
         inner join V$SQL q on s.SQL_HASH_VALUE = q.HASH_VALUE
where s.SID in (select l.SESSION_ID
                from V$LOCKED_OBJECT l)
  and s.STATUS = 'ACTIVE';
杀死锁
alter system kill session 'v$session.sid,v$session.serial#';
文章来源:https://blog.csdn.net/P923284735/article/details/135021160
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。