Oracle 锁冲突

 目录

 

1.什么是锁冲突

2.锁冲突的可能原因

3.检测锁冲突

4.解决锁冲突

         5.死锁


1.什么是锁冲突

         锁冲突经常发生,但通常会随着时间流逝通过入队机制得到解决。只有极少数情况下,锁冲突可能需要管理员干预。比如,事务处理 2 在 9:00:00 获取了对某一行的锁且 忘记了提交,从而留下了锁。事务处理 1 在 9:00:05 尝试更新整个表,因此需要锁定所有 行。但事务处理 2 会阻塞事务处理 1,直到 16:30:01 事务处理 2 提交为止。

         这种情况下,用户要尝试执行事务处理 1,就一定要与管理员联系以获得帮助,DBA 必须检测冲突并解决冲突。

2.锁冲突的可能原因

   1) .未提交更改; 

   2) .长时间运行事务处理; 

   3) .不必要的高锁定级别;

3.检测锁冲突

       使用 Enterprise Manager 中的“Blocking Sessions(阻塞会话)”页可找出锁冲突。有冲突的锁定请求以分层布局的形式显示,其中持有锁的会话位于顶部,下面是排队请求锁的所有会话。 

在“Performance(性能)”页上选择“Blocking Sessions (阻塞会话)”。

备注:单击“Session ID(会话 ID)”链接,查看关于锁定会话的 信息,包括实际 SQL 语句。

4.解决锁冲突

   使用 SQL 解决锁冲突

   输入指令确认堵塞会话ID

SQL> select SID, SERIAL#, USERNAME
     from V$SESSION where SID in
     (select BLOCKING_SESSION from V$SESSION)

   终止该会话:

SQL> alter system kill session '144,8982' immediate;

5.死锁

          死锁是锁冲突的一种特殊情况。两个或更多会话等待已被其中另一会话锁定的数据时,就 会发生死锁。因为每个会话都在等待另一个会话释放锁,所以任何一个会话都不能完成事 务处理,也就不能解决冲突。

          Oracle DB 会自动检测死锁并终止发生错误的语句。面对这种错误的适当做法是执行提交 或回退,这样做会释放该会话中的其它所有锁,以便其它会话可继续完成其事务处理。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值