由位列控制的 UNIQUE 约束

UNIQUE constraint controlled by a bit column(由位列控制的 UNIQUE 约束)
本文介绍了由位列控制的 UNIQUE 约束的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一张桌子,类似于

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

这对 (FieldID,FormID) 应该是唯一的,但前提是该行未被删除 (isDeleted=0).

The pair (FieldID,FormID) should be unique, BUT only if the row is not deleted (isDeleted=0).

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

Is it possible to define such a constraint in SQLServer 2008? (without using triggers)

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

P.S. Setting (FieldID, FormID, isDeleted) to be unique adds the possibility to mark one row as deleted, but i would like to have the chance to set n rows (per FieldID,FormID) to isDeleted = 1, and to have only one with isDeleted = 0

推荐答案

您可以拥有唯一的索引,使用 SQL Server 2008 过滤索引 功能,或者您可以对视图应用 UNIQUE 索引(穷人的过滤索引,适用于早期版本),但您不能具有您所描述的 UNIQUE 约束.

You can have a unique index, using the SQL Server 2008 filtered indexes feature, or you can apply a UNIQUE index against a view (poor man's filtered index, works against earlier versions), but you cannot have a UNIQUE constraint such as you've described.

过滤索引示例:

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

这篇关于由位列控制的 UNIQUE 约束的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Execute complex raw SQL query in EF6(在EF6中执行复杂的原始SQL查询)
Hibernate reactive No Vert.x context active in aws rds(AWS RDS中的休眠反应性非Vert.x上下文处于活动状态)
Bulk insert with mysql2 and NodeJs throws 500(使用mysql2和NodeJS的大容量插入抛出500)
Flask + PyMySQL giving error no attribute #39;settimeout#39;(FlASK+PyMySQL给出错误,没有属性#39;setTimeout#39;)
auto_increment column for a group of rows?(一组行的AUTO_INCREMENT列?)
Sort by ID DESC(按ID代码排序)