Oracle锁表

使用PL/SQL工具锁表后如何解决?


1.菜单栏DBATools——>数据库监视——>查看锁资源——>将SQL在窗口执行——>获取结果的session_id

2.菜单栏 工具(Tools)——>会话——>找到与之对应的sid——>关闭线程


为什么oracle会锁表:


  当oracle执行insert等DML语句时候,会首先自动在锁操作的表上申请一个TM锁,当TM锁获得后,在自动申请TX类型的锁。当两个活多个会话在表的同一条记录上执行DML语句的时候,第一个会话在记录上加速,其他的会话处于等待状态,一直到第一个会话提交后TX锁释放,其他的会话才可以加锁。考虑是因为两个insert语句同时试图向一个表中插入PK或unique值相同的数据,而造成其中会话被阻塞,等待其他会话提交或者回滚,因此造成死锁。这种情况,只要其中任何一个session提交,另外一个就会报出ORA-00001:违反唯一约束条件,死锁终止;或者其中一个session回滚,另外一个即可正常执行。



  说了这么多,其实大概的意思就是两个事物操作了一条数据,则就会造成死锁的情况;但是我遇见两次的死锁情况都是更新数据时候PL/SQL意外崩溃,导致了表的死锁情况,锁住不可怕,解开就好咯~


最近死锁情况比较多,找到了问题所在,Oracle不同于SQL Server数据库,当每次进行update、delete操作的时候,需要进行commit; 操作,否则会造成死锁。


为什么会出现这种情况?

当多个事物对一张表进行操作的时候,Oracle为了保证数据的安全性,当一个事物对表进行操作的时候,会将表进行锁定,这样,别的事物就不可以对该表进行操作;当一个事物对表的操作完成后,进行commit操作,Oracle会解除该表的锁定,下一个事物则可以对该表继续进行操作。
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值