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

  • 1、锁表原因

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

另一种场景:oracle报错:ORA-01013: user requested cancel of current operation
分析: 一般是因为update的时候被锁定了。

解决方案:使用有解锁权限的用户,解锁即可。

  • 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: 锁级别

查看被锁住的session


```bash
SELECT
  s.username,  -- 用户(表空间)
  s.sid,  -- session_id
  s.serial#, --   serial# 是序列号
  s.logon_time,  -- 登录时间
  l.locked_mode
FROM
    v$session s,  -- v$Session 是session视图
    v$locked_object l
WHERE
    s.sid = l.session_id
ORDER BY
    s.logon_time;


查看被锁住的session(带上dba_objects)
dba_objects.object_name可以显示对象名等,如表名。这样在kill的时候更有把握些。

SELECT
  s.sid,  -- session_id
  s.serial#, --   serial# 是序列号
  s.username,  -- 用户(表空间)
  s.logon_time,  -- 登录时间
  o.owner,
  o.object_name
FROM
    v$session s,  -- v$Session 是session视图
    v$locked_object l,
    dba_objects o
WHERE
    s.sid = l.session_id
    and l.object_id = o.object_id
ORDER BY
    s.logon_time;


 - 锁级别分为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引起的


```bash
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';  -- sid和serial# 共同确定一条数据

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

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

alter system kill session '1025,41' immediate;
  • 6、如何避免锁表

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

被生活耽误的旅行者

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值