为了账号安全,请及时绑定邮箱和手机立即绑定

如何创建允许空的唯一约束?

如何创建允许空的唯一约束?

湖上湖 2019-07-05 10:03:09
如何创建允许空的唯一约束?我希望在一个列上有一个唯一的约束,我将用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值,同时仍然检查实际数据的唯一性?
查看完整描述

3 回答

?
RISEBY

TA贡献1856条经验 获得超5个赞

SQLServer 2008+

属性创建接受多个NULL的唯一索引。WHERE条款。见回答如下.

SQLServer 2008之前

您不能创建唯一的约束并允许NULL。您需要设置一个默认值newid()。

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


查看完整回答
反对 回复 2019-07-05
?
holdtom

TA贡献1805条经验 获得超10个赞

您要寻找的确实是ANSI标准SQL:92、SQL:1999和SQL:2003的一部分,即唯一的约束必须不允许重复的非空值,而是接受多个空值。

然而,在Microsoft的SQLServer世界中,只允许一个NULL,但不允许多个NULL.

在……里面SQLServer 2008,可以根据排除NULL的谓词定义唯一筛选索引:

CREATE UNIQUE NONCLUSTERED INDEX idx_yourcolumn_notnullON YourTable(yourcolumn)WHERE yourcolumn IS NOT NULL;

在早期版本中,可以使用带有NOTNULL谓词的视图来强制执行约束。


查看完整回答
反对 回复 2019-07-05
  • 3 回答
  • 0 关注
  • 734 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信