微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何创建一个也允许空值的唯一约束?

如何解决如何创建一个也允许空值的唯一约束?

sql Server 2008 +

WHERE您可以使用一个子句创建一个接受多个 NULL的唯一索引。

sql Server 2008 之前

您不能创建 UNIQUE 约束并允许 NULL。您需要设置 NEWID() 的认值。

在创建 UNIQUE 约束之前将现有值更新为 NEWID() 其中 NULL。

解决方法

我想对要填充 GUID 的列有一个唯一的约束。但是,我的数据包含此列的空值。如何创建允许多个空值的约束?

这是一个示例场景。考虑这个模式:

CREATE TABLE People (
  Id INT CONSTRAINT PK_MyTable PRIMARY KEY IDENTITY,Name NVARCHAR(250) NOT NULL,LibraryCardId UNIQUEIDENTIFIER NULL,CONSTRAINT UQ_People_LibraryCardId UNIQUE (LibraryCardId)
)

然后查看此代码以了解我要实现的目标:

-- This works fine:
INSERT INTO People (Name,LibraryCardId) 
 VALUES ('John Doe','AAAAAAAA-AAAA-AAAA-AAAA-AAAAAAAAAAAA');

-- This also works fine,obviously:
INSERT INTO People (Name,LibraryCardId) 
VALUES ('Marie Doe','BBBBBBBB-BBBB-BBBB-BBBB-BBBBBBBBBBBB');

-- This would *correctly* fail:
--INSERT INTO People (Name,LibraryCardId) 
--VALUES ('John Doe the Second','AAAAAAAA-AAAA-AAAA-AAAA-AAAAAAAAAAAA');

-- This works fine this one first time:
INSERT INTO People (Name,LibraryCardId) 
VALUES ('Richard Roe',NULL);

-- THE PROBLEM: This fails even though I'd like to be able to do this:
INSERT INTO People (Name,LibraryCardId) 
VALUES ('Marcus Roe',NULL);

最后的语句失败并显示一条消息:

违反 UNIQUE KEY 约束“UQ_People_LibraryCardId”。无法在对象“dbo.People”中插入重复键。

如何更改我的架构和/或唯一性约束,以便它允许多个NULL值,同时仍检查实际数据的唯一性?

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。