【发布时间】:2010-10-20 12:57:39
【问题描述】:
我想对要使用 GUID 填充的列具有唯一约束。但是,我的数据包含此列的空值。如何创建允许多个空值的约束?
这是example scenario。考虑这个架构:
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 值,同时仍检查实际数据的唯一性?
【问题讨论】:
-
为标准兼容性投票的连接问题:connect.microsoft.com/SQLServer/Feedback/Details/299229
-
UNIQUE 约束并允许 NULL。 ?这是常识。这是不可能的
-
@flik,最好不要参考“常识”。那不是有效的论点。特别是考虑到
null不是价值而是价值的缺失。根据 SQL 标准,null不被视为等于null。那么为什么多个null应该是违反唯一性的呢?
标签: sql-server tsql