上的唯一键与唯一索引

上的唯一键与唯一索引

本文介绍了SQL Server 2008 上的唯一键与唯一索引的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个名为 countries 的表,我通过在 SQL Server 2008 上创建一个唯一键"类型的索引/键"来将 country_name 列定义为唯一的R2.

I have a table called countries and I define the country_name column to be unique by creating a "Index/Key" of type "Unique Key" on SQL Server 2008 R2.

但我有以下问题:

  1. 创建唯一键"类型的索引/键"是否会自动在此列上创建非聚集索引?
  2. 如果我将类型从唯一键"更改为索引"并且我将 IsUnique 值保持为是",那么会有什么不同吗?
  3. 那么为什么有两个选项唯一键"和索引"我认为这两个是一样的?
  1. will creating "Index/Key" of type "Unique Key" automatically create a non-clustered index on this column?
  2. if I change the type from being "Unique Key" to "Index" and I keep the IsUnique value to be "Yes",, then will there be any differences ?
  3. so why there are two options "Unique Key" and "Index" I think the two are the same ?

推荐答案

唯一约束在幕后实现为唯一索引,因此您如何指定它并不重要.我倾向于简单地实现它:

A unique constraint is implemented behind the scenes as a unique index, so it doesn't really matter how you specify it. I tend to implement it simply as:

ALTER TABLE dbo.foo ADD CONSTRAINT UQ_bar UNIQUE(bar);

有些人会创建唯一索引,例如

Some people create a unique index instead, e.g.

CREATE UNIQUE INDEX IX_UQ_Bar ON dbo.foo(bar);

区别在于意图 - 如果您要创建约束来强制执行唯一性/业务规则,则创建一个约束,如果您这样做是为了帮助查询性能,则创建唯一索引可能更合乎逻辑.同样,在幕后,它是相同的实现,但您实现目标的方式可能有助于记录您的意图.

The difference is in the intent - if you are creating the constraint to enforce uniqueness/business rules, you create a constraint, if you are doing so to assist query performance, it might be more logical to create a unique index. Again, under the covers it's the same implementation, but the road you take to get there may help document your intent.

我认为有多种选择可以同时遵守以前的 Sybase 功能以及遵守 ANSI 标准(即使唯一约束没有 100% 遵守标准,因为它们只允许一个 NULL 值 - 一个唯一的另一方面,索引可以通过在 SQL Server 2008 及更高版本上添加 WHERE 子句(WHERE col IS NOT NULL)来解决此问题.

I think there are multiple options to adhere to both previous Sybase functionality as well as to adhere to the ANSI standard (even though unique constraints don't adhere to the standard 100%, since they only allow one NULL value - a unique index, on the other hand, can work around this by adding a WHERE clause (WHERE col IS NOT NULL) on SQL Server 2008 and greater).

这篇关于SQL Server 2008 上的唯一键与唯一索引的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

08-13 16:34