相关疑难解决方法(0)

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

我希望对我将使用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)
)
Run Code Online (Sandbox Code Playgroud)

然后看看我正在尝试实现的代码:

-- 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: …
Run Code Online (Sandbox Code Playgroud)

t-sql sql-server

584
推荐指数
9
解决办法
23万
查看次数

具有重复NULL的SQL Server UNIQUE约束

可能重复:
如何创建唯一约束,该约束也允许sql server中的空值

我有一个表,我需要强制列具有唯一值.此列必须是可空的,并且应该允许业务逻辑使用多个NULL值,而其他重复值则不允许.

SQL Server UNIQUE约束在这种情况下并不好,因为它将NULL视为常规值,因此它将拒绝重复的NULL.

目前,BLL授予了价值唯一性,所以我不是在寻找一个肮脏的黑客来使其发挥作用.我只是想知道是否有一个干净的解决方案来在DB中强制执行此约束.

是的,我知道我可以写一个触发器来做到这一点:触发器是唯一的解决方案吗?(或者最好的解决方案呢?)

sql-server indexing

32
推荐指数
1
解决办法
2万
查看次数

标签 统计

sql-server ×2

indexing ×1

t-sql ×1