sql sever 创建带条件的唯一性索引

来源:互联网 发布:js unicode编码 编辑:程序博客网 时间:2024/06/05 15:16

查找了两天,终于解决了sql sever 创建带条件的唯一性索引,mark一下。
带条件的复合索引
索引字段 (a,b,c,d)
条件
a不为空的时候,(a,b,c,d)组成的复合索引唯一
a为空时,不做限制
代码如下:

IF EXISTS(SELECT object_name(object_id) tableName,name,type_desc from sys.indexes where name= 'idx')alter table tableName drop constraint idxGOcreate unique nonclustered index idx on table1(a,b,c,d) where a<> '';GO

ps:低版本的sql sever 不支持这种写法(2005不支持)。lz就被坑了,找了各种方法,结果发现是版本问题,说多了都是眼泪。

0 0