违反唯一键约束“...”。无法在对象“dbo.Cliente”中插入重复键。重复键值为(< NULL>) 。
违反唯一键约束“...”。无法在对象“dbo.Cliente”中插入重复键。重复键值为(< 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);
最后一个语句失败并显示以下消息:
违反唯一键约束 \"UQ_People_LibraryCardId\"。无法在对象 \"dbo.People\" 中插入重复键。
我该如何更改我的模式和/或唯一性约束,以允许多个NULL
值,同时仍检查实际数据的唯一性?
admin 更改状态以发布 2023年5月22日
SQL Server 2008及以上版本
你可以使用WHERE
子句创建一个可以接受多个NULL的唯一索引。请参见下面的答案。
在SQL Server 2008之前
你不能创建一个允许NULL值的唯一约束。你需要将默认值设置为NEWID()。
在创建唯一约束之前,将NULL的现有值更新为NEWID()。
你所需的就是 ANSI 标准 SQL:92、SQL:1999 和 SQL:2003 的一部分,也就是唯一约束必须禁止重复的非 NULL 值,但可以接受多个 NULL 值。
然而,在 Microsoft 的 SQL Server 中,单个 NULL 值是允许的,但多个 NULL 值是不允许的...
在 SQL Server 2008 中,可以基于谓词定义一个唯一的过滤索引来排除 NULL 值:
CREATE UNIQUE NONCLUSTERED INDEX idx_yourcolumn_notnull ON YourTable(yourcolumn) WHERE yourcolumn IS NOT NULL;
在早期版本中,可以使用带有 NOT NULL 谓词的视图来强制实施约束。