sql – 由位列控制的UNIQUE约束
发布时间:2021-01-26 01:08:48 所属栏目:MsSql教程 来源:网络整理
导读:我有一张桌子,像 FieldsOnForms( FieldID int (FK_Fields) FormID int (FK_Forms) isDeleted bit) 该对(FieldID,FormID)应该是唯一的,但仅当行未被删除时(isDeleted = 0). 是否可以在SQLServer 2008中定义这样的约束? (不使用触发器) 附:将(FieldID,Form
|
我有一张桌子,像 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 (编辑:云计算网_梅州站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- sql-server-2008 – 编写SQL查询的最佳方法,该查询检查列是
- Office 2003加限制功能 不许偷偷打印公司文件
- HTMl中标签中li横向排列的实现示例
- sql-server-2008 – 如何将值从动态SQL存储过程返回到实体框
- 肉眼无法触及 微距摄影最合适的三支镜头
- WindowsXP SP2 Beta版预览竟有时间限制
- sql-server – 如何有效地检查多列上的EXISTS?
- sql-server – SQL Server不在Windows启动时启动,而是手动启
- “冲击波”两变种今日再现 金山毒霸一路追杀
- 最锋利的Visual Studio Web开发工具扩展:Web Essentials使

