微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

sql-server – 将列添加到生产表

sql Server 2008 R2上向大型生产表添加列的最佳方法是什么?根据微软的在线书籍:

The changes specified in ALTER TABLE are implemented immediately. If the changes require modifications of the rows in the table,ALTER TABLE updates the rows. ALTER TABLE acquires a schema modify lock on the table to make sure that no other connections reference even the Metadata for the table during the change,except online index operations that require a very short SCH-M lock at the end.

(http://msdn.microsoft.com/en-us/library/ms190273.aspx)

在具有数百万行的大型表上,这可能需要一段时间.停电是唯一的选择吗?处理这种情况的最佳方法是什么?

解决方法

“这取决于”

如果添加不需要向行添加数据的列,则可以非常快.

例如,添加int或char需要物理行移动.添加一个没有认值的可空varchar不应该(除非NULL位图需要扩展)

您需要在已恢复的生产副本上进行尝试才能获得估算值

如果必须在十亿行表上重新添加索引和键,则创建新表,复制,重命名可能需要更长时间.

我已经改变了十亿行表,花了几秒钟来添加一个可以为空的列.

我先说过先备用吗?

原文地址:https://www.jb51.cc/mssql/79378.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐