Oracle数据库表被锁怎么查询和解锁


这篇文章主要介绍“Oracle数据库表被锁怎么查询和解锁”,在日常操作中,相信很多人在Oracle数据库表被锁怎么查询和解锁问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Oracle数据库表被锁怎么查询和解锁”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

1、锁表原因

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

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

selectcount(*)fromv$locked_object;select*fromv$locked_object;

3、查看哪个表被锁

selectb.owner,b.object_name,a.session_id,a.locked_modefromv$locked_objecta,dba_objectsbwhereb.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引起的

selecta.OS_USER_NAME,c.owner,c.object_name,b.sid,b.serial#,logon_timefromv$locked_objecta,v$sessionb,dba_objectscwherea.session_id=b.sidanda.object_id=c.object_idorderbyb.logon_time;

5、杀掉对应进程

altersystemkillsession'1025,41';

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

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

altersystemkillsession'1025,41'immediate;

6、如何避免锁表

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

到此,关于“Oracle数据库表被锁怎么查询和解锁”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注主机评测网网站,小编会继续努力为大家带来更多实用的文章!


上一篇:go语言规范RESTful?API业务错误处理的方法是什么

下一篇:基于Python如何实现彩票小游戏


Oracle数据库
Copyright © 2002-2019 测速网 https://www.inhv.cn/ 皖ICP备2023010105号 城市 地区 街道
温馨提示:部分文章图片数据来源与网络,仅供参考!版权归原作者所有,如有侵权请联系删除!
热门搜索