由列位控制的UNIQUE约束

jar*_*ics 6 sql sql-server database-design unique-constraint

我有一张桌子,像

FieldsOnForms(
 FieldID int (FK_Fields)
 FormID int (FK_Forms)
 isDeleted bit
)
Run Code Online (Sandbox Code Playgroud)

该对(FieldID,FormID)应该是唯一的,但仅当未删除该行时(isDeleted = 0).

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

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

Dam*_*ver 13

你可以有一个唯一索引,使用SQL Server 2008的过滤索引功能,也可以对视图应用唯一指数(穷人的筛选指标,工作针对早期版本),但你不能有一个独特的约束,如你已经描述.

过滤索引的示例:

 CREATE UNIQUE NONCLUSTERED INDEX IX_FieldsOnForms_NonDeletedUnique ON FieldsOnForms (FieldID,FormID) WHERE isDeleted=0
Run Code Online (Sandbox Code Playgroud)