oracle数据库锁表解决办法

Posted 迷神图卷

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle数据库锁表解决办法相关的知识,希望对你有一定的参考价值。

当多人同时操作oracle数据库的同一张表的时候,经常会造成锁表现象,这时需要手动进行解锁。

首先:先看下那些表被锁住,程序如下:

1,

select b.owner,b.object_name,a.session_id,a.locked_mode
from v$locked_object a,dba_objects b
where b.object_id = a.object_id;

2,

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;

然后:杀死进程中的会话,程序如下:

alter system kill session sid,serial#;

//举例:

alter system kill session 29,5497;

//其中29指第一条sql中sid列内容,5497指第二条sql中serial#列内容

 

其他解决办法:

删除会话需要有DBA权限,使用sys账号或者system账号

如果忘记了这两个账号密码,需要等到session过期。生产环境是之前离职的同事部署的,账号密码也已经忘了。

查询的时候session登陆时间是早上9点28分,我在中午12点的时候查询的时候session已经过期了,表已经解锁。session过期时间大概在2到3个小时左右。

以上是关于oracle数据库锁表解决办法的主要内容,如果未能解决你的问题,请参考以下文章

oracle 锁表、解锁的语句

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

查看oracle是否锁表以及解决方法

Oracle数据库老是被锁表,而且用解锁语句解开后,紧跟着又出来一堆锁,解也解不完

Oracle查看锁表及解锁办法

Oracle出现锁表查询并快速解决