1、锁表原因

可能是修改表中的数据,忘了提交事务会造成锁表。

Oracle数据库操作中,我们有时会用到锁表查询以及解锁和kill进程等操作。

2、锁表查询的代码有以下的形式

select count(*) from v$locked_object;

select * from v$locked_object;


3、查看哪个表被锁

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;


4、查看是哪个session引起的

select a.OS_USER_NAME, c.owner, c.object_name, b.sid, b.serial#, logon_time
  from v$locked_object a, v$session b, dba_objects c
 where a.session_id = b.sid
   and a.object_id = c.object_id
 order by b.logon_time;


5、杀掉对应进程
执行命令:

alter system kill session '1025,41'; 

 需要用户有管理员的权限操作,其中1025为sid,41为serial#。

6、如何避免锁表

常见问题是用户更新操作没有提交事务,所以:如果单独更新操作,需要写2个操作 SQL,一个是更新操作SQL语句,另一个是commit语句提交事务。

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐