本网站(662p.com)打包出售,且带程序代码数据,662p.com域名,程序内核采用TP框架开发,需要联系扣扣:2360248666 /wx:lianweikj
精品域名一口价出售:1y1m.com(350元) ,6b7b.com(400元) , 5k5j.com(380元) , yayj.com(1800元), jiongzhun.com(1000元) , niuzen.com(2800元) , zennei.com(5000元)
需要联系扣扣:2360248666 /wx:lianweikj
Oracle数据库表被锁如何查询和解锁详解
phpren · 142浏览 · 发布于2023-03-08 +关注

作为一个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语句提交事务。


相关推荐

PHP实现部分字符隐藏

沙雕mars · 1325浏览 · 2019-04-28 09:47:56
Java中ArrayList和LinkedList区别

kenrry1992 · 908浏览 · 2019-05-08 21:14:54
Tomcat 下载及安装配置

manongba · 970浏览 · 2019-05-13 21:03:56
JAVA变量介绍

manongba · 962浏览 · 2019-05-13 21:05:52
什么是SpringBoot

iamitnan · 1086浏览 · 2019-05-14 22:20:36
加载中

0评论

评论
我从小喜欢编程,一直在学习中,从未停止,未来也是如此!
小鸟云服务器
扫码进入手机网页