系统城装机大师 - 固镇县祥瑞电脑科技销售部宣传站!

当前位置:首页 > 数据库 > oracle > 详细页面

Oracle数据库表被锁如何查询和解锁详解

时间:2023-03-09来源:系统城装机大师作者:佚名

1、锁表原因

可能是修改表中的数据,忘了提交事务会造成锁表。 Oracle数据库操作中,我们有时会用到锁表查询以及解锁和kill进程等操作。

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

1
2
select count(*) from v$locked_object;
select * from v$locked_object;

3、查看哪个表被锁

1
2
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;
  • OWNER :数据表的所有者用户
  • OBJECT_NAME: 被锁住的表名
  • SESSION_ID: 会话ID
  • LOCKED_MODE: 锁级别

锁级别分为6级:

  • 1级锁有:Select 2级锁有:Select for update,Lock For Update,Lock Row Share
  • 3级锁有:Insert, Update, Delete, Lock Row Exclusive
  • 4级锁有:Create Index,Lock Share
  • 5级锁有:Lock Share Row Exclusive
  • 6级锁有:Alter table, Drop table, Drop Index, Truncate table, Lock Exclusive

4、查看是哪个session引起的

1
2
3
4
5
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、杀掉对应进程

1 alter system kill session '1025,41';

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

如果有ora-00031错误,则在后面加immediate;

1 alter system kill session '1025,41' immediate;

6、如何避免锁表

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

总结

到此这篇关于Oracle数据库表被锁如何查询和解锁的文章就介绍到这了

分享到:

相关信息

  • 一文掌握Oracle中的Dual系统表

    Dual表是Oracle提供的最小的工作表(其实是一种虚拟表),是sys用户下的一张内部表,只有一行一列(一列:DUMMY,一列:DUMMY,其数据类型为:VARCHAR2(1)),接下来通过本文给大家分享Oracle中的Dual系统表,需要的朋友可以参考下...

    2022-10-02

  • Oracle中dbms_output.put_line的用法实例

    1、enable: 2、disable: 3、put: 4、put_line: 5、new_line: 6、get_line(value, index): 7、get_lines(array, index)...

    2022-06-22

系统教程栏目

栏目热门教程

人气教程排行

站长推荐

热门系统下载