ORACLE数据库表解锁record is locked by another user

1、查锁

select t2.username,t2.sid,t2.serial#,t2.logon_time from v$locked_object t1,v$session t2 where t1.session_id=t2.sid order by t2.logon_time;
  1. 解锁
alter system kill session 'sid,serial#';

alter system kill session '945,48733';    

1)用dba用户执行以下语句
通过检查数据库表,能够检查出是哪一条语句被死锁,产生死锁的机器是哪一台。

select username,lockwait,status,machine,program from v$session where sid in
(select session_id from v$locked_object)

如果有输出的结果,则说明有死锁,且能看到死锁的机器是哪一台。字段说明:

  • Username:死锁语句所用的数据库用户;
  • Lockwait:死锁的状态,如果有内容表示被死锁。
  • Status: 状态,active表示被死锁 Machine: 死锁语句所在的机器。
  • Program: 产生死锁的语句主要来自哪个应用程序。

2)用dba用户执行以下语句,可以查看到被死锁的语句。

select sql_text from v$sql where hash_value in (select sql_hash_value from v$session where sid in
(select session_id from v$locked_object))

查询哪些人或进程被锁使用如下SQL:

SELECT OBJECT_ID,SESSION_ID,SERIAL# ,a.oracle_username,a.os_user_name,a.process
FROM V$LOCKED_OBJECT a , V$SESSION  WHERE a.SESSION_ID=SID;
posted @ 2020-06-30 20:08  我有满天星辰  阅读(58)  评论(0编辑  收藏  举报