Oracle 死锁与索引

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

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

你可能感兴趣的:(Oracle 死锁与索引)