2 lxk7182 lxk7182 于 2014.11.27 16:52 提问

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

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

3个回答

CSDNJavaLiwei
CSDNJavaLiwei   2014.11.27 19:58

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

luxiuwen
luxiuwen   2014.11.27 17:00

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

CSDNJavaLiwei
CSDNJavaLiwei   2014.11.27 19:57

当ORACLE执行CRUD时DML语句时,都会被锁住只到提交或者回滚之后才会解锁。

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!