Oracle外键需要建索引吗?

Posted 左正

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Oracle外键需要建索引吗?相关的知识,希望对你有一定的参考价值。

关于Oracle中的外键,首先要说明一下。

1. 除非已定义了父表主键或唯一键约束,否则oracle将不允许创建子表的外键约束。

2. 在定义外键约束时,oracle不会自动创建索引,所以必须手动在与外键约束相关的列上创建索引。

所以我们这里要研究的是否需要在子表中创建索引,因为父表中对应的列是一定有索引的。

如果子表中的外键不创建索引,将导致两个问题。

1. 影响性能。 如果子表外键没有创建索引,那么当父表查询关联子表时,子表将进行全表扫描。

2. 影响并发。 如果子表外键没有创建索引,那么在子表进行DML操作时,将会锁住整个父表。

 

所以,我们应该尽量考虑在外键上面创建索引。

以上是关于Oracle外键需要建索引吗?的主要内容,如果未能解决你的问题,请参考以下文章

怎样在oracle中创建主外键和唯一约束

oracle查询表信息(索引,外键,列等)

Oracle查看表索引、主键、外键、约束

ORACLE 数据库需要创建索引的规则

通过在Oracle子表外键上建立索引提高性能

ORACLE: 查询(看)表的主键外键唯一性约束和索引