我想对要填充 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值,同时仍检查实际数据的唯一性?
NULL
WHERE您可以使用一个子句创建一个接受多个 NULL的唯一索引。
WHERE
您不能创建 UNIQUE 约束并允许 NULL。您需要设置 NEWID() 的默认值。
在创建 UNIQUE 约束之前将现有值更新为 NEWID() 其中 NULL。