首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >我如何创建一个允许空值的唯一约束?

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

提问于 2017-12-19 11:54:49
回答 2关注 0查看 294

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

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

代码语言:txt
复制
代码语言:txt
复制
CREATE TABLE People (
代码语言:txt
复制
  Id INT CONSTRAINT PK_MyTable PRIMARY KEY IDENTITY,
代码语言:txt
复制
  Name NVARCHAR(250) NOT NULL,
代码语言:txt
复制
  LibraryCardId UNIQUEIDENTIFIER NULL,
代码语言:txt
复制
  CONSTRAINT UQ_People_LibraryCardId UNIQUE (LibraryCardId)
代码语言:txt
复制
)

然后看看我想要实现的代码:

代码语言:txt
复制
-- This works fine:
代码语言:txt
复制
INSERT INTO People (Name, LibraryCardId) 
代码语言:txt
复制
 VALUES ('John Doe', 'AAAAAAAA-AAAA-AAAA-AAAA-AAAAAAAAAAAA');
代码语言:txt
复制
代码语言:txt
复制
-- This also works fine, obviously:
代码语言:txt
复制
INSERT INTO People (Name, LibraryCardId) 
代码语言:txt
复制
VALUES ('Marie Doe', 'BBBBBBBB-BBBB-BBBB-BBBB-BBBBBBBBBBBB');
代码语言:txt
复制
代码语言:txt
复制
-- This would *correctly* fail:
代码语言:txt
复制
--INSERT INTO People (Name, LibraryCardId) 
代码语言:txt
复制
--VALUES ('John Doe the Second', 'AAAAAAAA-AAAA-AAAA-AAAA-AAAAAAAAAAAA');
代码语言:txt
复制
代码语言:txt
复制
-- This works fine this one first time:
代码语言:txt
复制
INSERT INTO People (Name, LibraryCardId) 
代码语言:txt
复制
VALUES ('Richard Roe', NULL);
代码语言:txt
复制
代码语言:txt
复制
-- THE PROBLEM: This fails even though I'd like to be able to do this:
代码语言:txt
复制
INSERT INTO People (Name, LibraryCardId) 
代码语言:txt
复制
VALUES ('Marcus Roe', NULL);

最后的声明失败并带有一条消息:

违反UNIQUE KEY约束“UQ_People_LibraryCardId”。不能在对象'dbo.People'中插入重复的键。

我怎样才能改变我的模式和/或唯一性约束,以便它允许多个NULL值,同时仍然检查实际数据的唯一性?

回答

和开发者交流更多问题细节吧,去 写回答
相关文章

相似问题

相关问答用户
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档