我有一张桌子,像
FieldsOnForms( FieldID int (FK_Fields) FormID int (FK_Forms) isDeleted bit )
该对(FieldID,FormID)应该是唯一的,但仅当行未被删除时(isDeleted = 0).
是否可以在sqlServer 2008中定义这样的约束? (不使用触发器)
附:将(FieldID,FormID,isDeleted)设置为唯一添加了将一行标记为已删除的可能性,但我希望有机会将n行(每个FieldID,FormID)设置为isDeleted = 1,并且只有一行具有isDeleted = 0
解决方法
您可以使用sql Server 2008
filtered indexes功能获得唯一索引,或者您可以对视图应用UNIQUE索引(穷人的过滤索引,适用于早期版本),但您不能具有UNIQUE约束,例如您所描述的.
过滤索引的示例:
CREATE UNIQUE NONCLUSTERED INDEX IX_FieldsOnForms_NonDeletedUnique ON FieldsOnForms (FieldID,FormID) WHERE isDeleted=0