如何創建允許空的唯一約束?我希望在一個列上有一個唯一的約束,我將用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);最后一條語句失敗,其中包含一條消息:違反唯一密鑰約束‘UQ_People_Library aryCardId’。無法在對象‘dbo.People’中插入重復鍵。如何更改架構和/或唯一性約束,使其允許多個NULL值,同時仍然檢查實際數據的唯一性?
如何創建允許空的唯一約束?
湖上湖
2019-07-05 10:03:09