使用PL/SQL工具锁表后如何解决?
为什么oracle会锁表:
说了这么多,其实大概的意思就是两个事物操作了一条数据,则就会造成死锁的情况;但是我遇见两次的死锁情况都是更新数据时候PL/SQL意外崩溃,导致了表的死锁情况,锁住不可怕,解开就好咯~
最近死锁情况比较多,找到了问题所在,Oracle不同于SQL Server数据库,当每次进行update、delete操作的时候,需要进行commit; 操作,否则会造成死锁。
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会解除该表的锁定,下一个事物则可以对该表继续进行操作。