我想对我将要用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值,同时仍然检查实际数据的唯一性?
相似问题