作为一个IT技术人员,可能经常遇到在使用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数据库表被锁如何查询和解锁的文章就介绍到这了,更多相关Oracle数据库表被锁内容请搜索编程学习网以前的文章希望大家以后多多支持编程学习网!
沃梦达教程
本文标题为:Oracle数据库表被锁如何查询和解锁详解
猜你喜欢
- 搭建单机Redis缓存服务的实现 2023-07-13
- 在阿里云CentOS 6.8上安装Redis 2023-09-12
- Mongodb启动报错完美解决方案:about to fork child process,waiting until server is ready for connections. 2023-07-16
- 基于Python制作一个简单的文章搜索工具 2023-07-28
- Numpy中如何创建矩阵并等间隔抽取数据 2023-07-28
- SQLSERVER调用C#的代码实现 2023-07-29
- MySQL8.0.28安装教程详细图解(windows 64位) 2023-07-26
- Oracle 删除大量表记录操作分析总结 2023-07-23
- redis清除数据 2023-09-13
- SQL Server 2022 AlwaysOn新特性之包含可用性组详解 2023-07-29