.key_constraints WHERE parent_object_id = OBJECT_ID('TableUniqueKey')
SELECT * FROM sys.key_constraints WHERE parent_object_id = OBJECT_ID('TableUniqueIndex')
SELECT object_name(object_id),name,index_id,type_desc,is_unique,is_unique_constraint
FROM sys.indexes WHERE object_name(object_id) IN ('TableUniqueKey','TableUniqueIndex')
?

唯一键约束 [TableUniqueKey] 不是 check 约束,是属于一种为 UNIQUE_CONSTRAINT 的约束。而他们的索引都有唯一性约束。
此外,还可以通过以下检查他们的区别:
?
EXEC sp_helpconstraint 'TableUniqueKey'
EXEC sp_helpconstraint 'TableUniqueIndex'
EXEC sp_helpindex 'TableUniqueKey'
EXEC sp_helpindex 'TableUniqueIndex'
-- EXEC sp_help 'TableUniqueKey'
-- EXEC sp_help 'TableUniqueIndex'
?
对比索引描述中,唯一键 比 唯一 索引多了 unique key 。
?
--唯一键不出错
EXEC sp_help [IX_TableUniqueKey_name]
EXEC sp_helpindex [IX_TableUniqueKey_name]
EXEC sp_helpconstraint [IX_TableUniqueKey_name]
--唯一索引出错
EXEC sp_help [IX_UniqueIndex_name]
EXEC sp_helpindex [IX_UniqueIndex_name]
EXEC sp_helpconstraint [IX_UniqueIndex_name]
上面可以看出,唯一不同的是: 唯一键 比 唯一索引 多了一种叫做 "unique key" 的约束
?
现在禁用索引:
?
--禁用索引/约束(均可被禁用)
ALTER INDEX [IX_TableUniqueKey_name] ON [dbo].[TableUniqueKey] DISABLE
ALTER INDEX [IX_UniqueIndex_name] ON [dbo].[TableUniqueIndex] DISABLE
插入重复数据:
?
?
--插入重复值,正常
INSERT INTO [dbo].[TableUniqueKey] SELECT 3,NULL
INSERT INTO [dbo].[TableUniqueIndex]SELECT 3,NULL
数据都能正常插入,约束或索引被禁用了。对于唯一键约束,也是禁用索引吗?
?
函数 ObjectProperty() 的参数 CnstIsDisabled 可以确认约束是否被禁用。
?
SELECT ObjectProperty(object_id('IX_TableUniqueKey_name'),'CnstIsDisabled')
结果为 0 ,即约束没有被禁用,也就是说禁用的是索引,唯一键约束中,唯一性是依赖于其默认创建的唯一索引来约束的!
?
现在重建索引:
?
--删除重复
DELETE FROM [dbo].[TableUniqueKey] WHERE ID = 3
DELETE FROM [dbo].[TableUniqueIndex] WHERE ID = 3
/*对索引的更改*/
--重建索引
ALTER INDEX [IX_TableUniqueKey_name] ON [dbo].[TableUniqueKey] REBUILD
ALTER INDEX [IX_UniqueIndex_name] ON [dbo].[TableUniqueIndex] REBUILD
--更改部分索引参数
ALTER INDEX [IX_TableUniqueKey_name] ON [dbo].[TableUniqueKey] SET ( ALLOW_ROW_LOCKS = ON )
GO
ALTER INDEX [IX_UniqueIndex_name] ON [dbo].[TableUniqueIndex] SET ( ALLOW_ROW_LOCKS = ON )
GO
两种索引其实还是可以更改一下参数的。使用窗口打开查看,唯一键约束的索引有些是不能更改的。
?



唯一键约束的索引不能像正常的索引使用太多的索引参数,因为唯一键约束与其索引同在。而单独创建的唯一索引可以设置更多的参数,如 PAD_INDEX, FILLFACTOR, IGNORE_DUP_KEY, DROP_EXISTING, STATISTICS_NORECOMPUTE, and SORT_IN_TEMPDB 。
总的来说,其实唯一键键约束和唯一索引功能是一样的: "唯一性" + "索引"
唯一键键约束 只是作为一种独特的约束(如主键约束,唯一键约束,check约束,外键约束 的一种),以约束的形式管理.但是同时又自动创建了唯一非聚集索引,也就有了索引的性能和部分功能.实际上唯一键约束是用唯一索引来约束的。
唯一索引 就是一种索引,它对某字段进行唯一性检查,同时可以设置各种参数,非常灵活。
那么我们在创建列的唯一性时,到底使用哪一种较好呢?(个人理解)
唯一键约束在表中是必定存在的约束的,唯一键约束的索引存在于一个分区中,并且不会像索引那样可以更改。因为索引可以随时改动(当然也不会经常改动),索引个人建议还是用唯一索引更灵活。管理约束还得管理索引,而管理索引,一个就好了。但是对于一些高可用性,也要注意索引是否在其他地方也存在。