在已经存在主键或唯一键约束的列上创建索引

Posted

技术标签:

【中文标题】在已经存在主键或唯一键约束的列上创建索引【英文标题】:Creating indexes on columns where primary key or unique key constraints already present 【发布时间】:2017-10-19 15:34:18 【问题描述】:

我目前正在学习 Oracle 中的索引。 在 Oracle documentation 中,可以找到以下内容:

虽然数据库会在具有完整性约束的列上为您创建索引,但建议在此类列上显式创建索引。

这里有人能告诉我这背后的理由吗? 如果数据库自动创建索引,我们为什么要在这些列上显式创建另一个索引?

【问题讨论】:

好问题。我希望那句话中有“不推荐”。也许Oracle只创建一次索引,建议以防完整性约束发生变化。 @GordonLinoff - 在约束发生变化时保持索引是一个很好的理由;但是,出于这个目的,Oracle 在禁用约束时提供了KEEP INDEX 选项。 【参考方案1】:

我唯一的想法是那些自动创建的索引有一些奇怪的名称,要么生成为SYS%,要么从约束名称继承名称。为索引保留一些命名约定可能会更好

【讨论】:

还有其他区别——您可以通过显式创建索引来控制存储等。当系统为您执行此操作时,情况并非如此。【参考方案2】:

至少,如果你明确地创建一个索引,你可以给它一个有意义的名字。如果您随后需要按名称引用索引,它将采用人类可读的形式。

请注意,您可以在创建约束时在USING INDEX 子句中创建显式索引。文档有几个例子:https://docs.oracle.com/cd/B28359_01/server.111/b28310/indexes003.htm#ADMIN11725

【讨论】:

以上是关于在已经存在主键或唯一键约束的列上创建索引的主要内容,如果未能解决你的问题,请参考以下文章

Oracle数据库主键约束与唯一索引有啥区别?

主键、外键和索引的区别?

[Oracle]约束(constraint)

Oracle数据库主键约束与唯一索引有啥区别?

同一列上的多个索引

sqlserver表的唯一键约束怎么设置?