-
为什么insert操作会把整张表都锁住呢?
3个回答
按赞数排序
- liwei_Struggle 2014.11.27 19:58
![CSDNJavaLiwei](http://avatar.csdn.net/A/C/7/3_csdnjavaliwei.jpg)
查的时候不会锁住,只有曾删改才会
- 俺是卢浩铖 2014.11.27 17:00
![luxiuwen](http://avatar.csdn.net/7/1/C/3_luxiuwen.jpg)
当ORACLE执行insert等DML语句时,会首先自动在所要操作的表上申请一个TM锁,当TM锁获得后,再自动申请TX类型的锁。当两个或多个会话在表的同一条记录上执行DML语言时,第一个会话在记录上加锁,其它的会话处于等待状态,一直到第一个会话提交后TX锁释放,其它的会话才可以加锁。考虑是因为两个insert语句同时试图向一个表中插入PK或unique值相同的数据,而造成其中会话被阻塞,等待其它会话提交或回滚,因而造成死锁。这种情况,只要其中任何一个session提交,另外一个就会报出ORA-00001:违反唯一性约束条件,死锁终止;或者其中一个session回滚,另外一个即可正常执行。