我有一张 table ,像

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

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

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

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

最佳答案

您可以使用SQL Server 2008 filtered indexes功能获得唯一索引,也可以对 View 应用UNIQUE索引(穷人过滤索引,对较早版本适用),但是不能像上面描述的那样具有UNIQUE约束。

筛选索引的示例:

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

关于sql - 由位列控制的UNIQUE约束,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/3997837/

10-10 06:40