13

我正在写这篇文章以跟进更改 SQL Server 中列的数据类型

我之前的问题是我是否需要删除所有索引和约束,并且回答我确实需要删除它们。

所以当我在网上浏览这个主题时,我遇到了一些帖子说最好禁用和启用索引,而不是删除和重新创建它们。

那么哪种方法更好呢?禁用索引是否也允许您更改列的数据类型?两者有什么区别?

删除和创建索引的语句

DROP INDEX UX_1_COMPUTATION ON  dbo.Computation 

ALTER TABLE dbo.Computation
ALTER COLUMN ComputationID NVARCHAR(25) not null

CREATE UNIQUE INDEX UX_1_COMPUTATION ON dbo.Computation (ComputationID);

带有禁用和启用索引的语句

ALTER INDEX [UX_1_COMPUTATION ] ON  dbo.Computation DISABLE

ALTER TABLE dbo.Computation
ALTER COLUMN ComputationID NVARCHAR(25) not null

ALTER INDEX [UX_1_COMPUTATION ] ON dbo.Computation REBUILD;
4

1 回答 1

7

禁用索引是否也允许您更改列的数据类型?

它基于您选择的索引类型。当表上的聚集索引被禁用时,您无法修改列数据类型。如果您的索引是非聚集索引,那么您可以。

两者有什么区别?

禁用和删除索引的最大区别在于元数据和统计信息是否被持久化。如果禁用,它们是。如果掉落,它们不会。确保在执行任一操作之前仔细权衡您的选项,并且始终有办法重新创建可用的索引。

哪种方法更好?

在您的情况下,我建议删除并重新创建索引。

于 2014-12-31T05:32:31.910 回答