如果列NOT NULL UNIQUE CLUSTERED INDEX将是主键,则可能的性能更改

问题描述 投票:0回答:2

如果列被声明为NOT NULL UNIQUE CLUSTERED INDEX,那么它会使PRIMARY KEY对性能或任何实际的变化做任何改变吗?

sql-server database-indexes
2个回答
2
投票

它不应该有任何影响。在少数手抄1中,PRIMARY KEYUNIQUE KEY相同,附加条件是所有列都被强制为非NULL。因此,将此列装饰为PRIMARY KEY不应导致实现该表的物理数据结构2的任何更改。

CLUSTERED是一个完全独立的概念 - 有时与PRIMARY KEY混为一谈。如果表没有CLUSTERED INDEX并且添加了PRIMARY KEY,那么默认情况下,这也将被定义为CLUSTERED INDEX。但是如果需要的话,这种行为可以被覆盖,而且这两种行为在实践中并没有结合在一起。


1I实际上在这一点上无法想到任何相关的差异,但这只是为了避免挑剔,希望如此。

2聚簇索引和任何非聚簇索引和统计信息。


1
投票

PRIMARY KEY不允许null并且必须是唯一的,约束NOT NULL UNIQUE也可以像PRIMARY KEY那样将相似的规则应用到列中,但是,你的表只能有一个主键,但可能有多个NOT NULL UNIQUE列。

并且通过NOT NULL UNIQUE CLUSTERED INDEXPRIMARY KEY,两者都将按照CLUSTERED INDEX进行存储,排序和结构化,因此在选择,插入,更新或删除的操作性能基础上,应该没有什么不同

唯一的区别可能在于元数据本身。

© www.soinside.com 2019 - 2024. All rights reserved.