Oracle 死锁与索引

开发的系统在重复提交更新操作(需要先删除数据再添加数据,涉及多张表),发生死锁:

ORA-00060: 等待资源时检测到死锁
网上找到的相关理论这样说: oracle在删除主表的时候会去寻找所有以主表的主键作为外键的数据表,然后看去看从表是否有该外键的索引,如果没有则会对整个从表施加表级锁,然后对从表进行全表扫描。当然如果从表存在外键的索引,会去访问对应的索引,而不会对从表本身进行加锁。
给外键字段创建索引后再测试,没有出现死锁的问题,创建索引的语句:
create index INDEX2_DISCUSSION on  DISCUSSION(USER_ID);
两个小问题:
    1、能不能在建表的同时创建索引? 不可以。
    2、不删除索引能不能直接删除表? 可以,删除表的时候会自动删除索引。

转载于:https://my.oschina.net/u/173975/blog/113142

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值