小编典典

由位列控制的UNIQUE约束

sql

我有一张表,像

FieldsOnForms(
 FieldID int (FK_Fields)
 FormID int (FK_Forms)
 isDeleted bit
)

该对(FieldID,FormID)应该是唯一的,但只有在不删除该行(isDeleted = 0)的情况下,才可以。

是否可以在SQLServer 2008中定义这样的约束?(不使用触发器)

PS设置(FieldID,FormID,isDeleted)是唯一的,增加了将一行标记为已删除的可能性,但是我希望有机会将n行(每个FieldID,FormID)设置为isDeleted
= 1,并且只有一个与isDeleted = 0


阅读 132

收藏
2021-05-05

共1个答案

小编典典

您可以使用SQL Server 2008筛选索引功能来拥有唯一 索引
,也可以对视图应用UNIQUE索引(穷人筛选索引,可用于较早版本),但是不能像这样使用UNIQUE约束描述。

筛选索引的示例:

 CREATE UNIQUE NONCLUSTERED INDEX IX_FieldsOnForms_NonDeletedUnique ON FieldsOnForms (FieldID,FormID) WHERE isDeleted=0
2021-05-05