为什么insert操作会把整张表都锁住呢?

为什么insert操作会把整张表都锁住呢?
spring oracle 锁表

项目中遇到一个很奇怪的问题:
问题描述:现在需要从项目外部导大量的数据到项目内,这个时候我起了一个spring事务往很多张表中去插入数据,这个时候其他用户访问系统去更新旧的数据的时候发现表被锁了。也就是说我在导入数据的时候,其他用户都不能对系统的表进行相应的更新操作。这是为什么????

3个回答

按赞数排序 
CSDNJavaLiwei
liwei_Struggle    2014.11.27 19:58

查的时候不会锁住,只有曾删改才会

luxiuwen
俺是卢浩铖    2014.11.27 17:00

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

你可能感兴趣的:(Oracle)