Oracle数据库表被锁怎么查询和解锁
这篇文章主要介绍“Oracle数据库表被锁怎么查询和解锁”,在日常操作中,相信很多人在Oracle数据库表被锁怎么查询和解锁问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Oracle数据库表被锁怎么查询和解锁”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
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;
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引起的
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#
如果有ora-00031错误,则在后面加immediate;
alter system kill session '1025,41' immediate;
6、如何避免锁表
常见问题是用户更新操作没有提交事务,
所以:如果单独更新操作,需要写2个操作 SQL,一个是更新操作SQL语句,另一个是commit语句提交事务。
到此,关于“Oracle数据库表被锁怎么查询和解锁”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341