oracle 父表 子表 dml,无索引的外键之主表子表DML操作实验及结论

子表上的insert 操作执行后不提交,会阻塞后续主表上的update、delete、insert操作(针对包含主键列的的操作),主表、

子表都是TM锁,外键加索引后消除阻塞问题。

create table test_pk1 (id number,pcol varchar2(1)) tablespace users;

alter table test_pk1 add constraint pk_test_pk1_id primary key(id) using index tablespace users;

insert into test_pk1 values(1,'A');

insert into test_pk1 values(2,'B');

insert into test_pk1 values(3,'C');

insert into test_pk1 values(4,'D');

insert into test_pk1 values(5,'E');

commit;

create table test_fk1 (id number,fcol varchar2(1)) tablespace users;

alter table test_fk1 add constraint fk_test_fk1_id foreign key(id) references test_pk1(id);

insert into test_fk1 values(1,'a');

insert into test_fk1 values(2,'a');

commit;

场景一:子表执行insert操作后不提交,另一个事务对主表进行update、delete、insert

--子表

insert into test_fk1 values(5,'d');

--主表

update test_pk1 set id=55 where id='4';

delete test_pk1 where id='3';

insert into test_pk1 values(6,'F');

结论:子表上的insert 操作执行后不提交,会阻塞后续主表上的update、delete、insert操作(针对包含主键列的的操作),

主表、子表都是TM锁。

--给外键加索引后,然后进行主表的update、delete、insert操作看是否会有影响

create index idx_id on test_fk1(id);

结论:外键加索引后消除阻塞问题。

场景二:子表执行update操作后不提交,另一个事务对主表进行update、delete、insert

--子表

update test_fk1 set fcol='b' where id='2';

--主表

update test_pk1 set id=55 where id='4';

delete test_pk1 where id='3';

insert into test_pk1 values(6,'F');

结论:子表上的update操作执行后不提交,对主表上的update、delete、insert操作无影响。

场景三:子表执行delete操作后不提交,另一个事务对主表进行update、delete、insert

--子表

delete test_fk1 where id='2';

--主表

update test_pk1 set id=55 where id='4';

delete test_pk1 where id='3';

insert into test_pk1 values(6,'F');

结论:子表上的delete操作执行后不提交,对主表上的update、delete、insert操作无影响。

场景四:主执行delete操作后不提交,另一个事务对子表进行update、delete、insert

--主表

delete test_pk1 where id='3';

--子表

update test_fk1 set fcol='A' where id='1';

insert into test_fk1 values(4,'d');

delete test_fk1 where id='2';

结论:主表上的delete操作执行后不提交,对子表上的update、delete、insert操作无影响。

场景五:主执行update操作后不提交,另一个事务对子表进行update、delete、insert

--主表

update test_pk1 set pcol='F' where id='5';

--子表

update test_fk1 set fcol='A' where id='1';

insert into test_fk1 values(4,'d');

delete test_fk1 where id='2';

结论:主表上的update操作执行后不提交,对子表上的update、delete、insert操作无影响。

场景五:主执行insert操作后不提交,另一个事务对子表进行update、delete、insert

--主表

insert into test_pk1 values(6,'F');

--子表

update test_fk1 set fcol='A' where id='1';

insert into test_fk1 values(4,'d');

delete test_fk1 where id='2';

结论:主表上的delete操作执行后不提交,对子表上的update、delete、insert操作无影响。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值