违反唯一键约束“...”。无法在对象“dbo.Cliente”中插入重复键。重复键值为(< NULL>) 。

19 浏览
0 Comments

违反唯一键约束“...”。无法在对象“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日
0
0 Comments

SQL Server 2008及以上版本

你可以使用WHERE子句创建一个可以接受多个NULL的唯一索引。请参见下面的答案

在SQL Server 2008之前

你不能创建一个允许NULL值的唯一约束。你需要将默认值设置为NEWID()。

在创建唯一约束之前,将NULL的现有值更新为NEWID()。

0
0 Comments

你所需的就是 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 谓词的视图来强制实施约束。

0