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

从大表中删除/删除列的方法

如何解决从大表中删除/删除列的方法

我的表有 119962649 行,大小超过 600 GB。

我想删除/删除 nvarchar(MAX) 类型的一列。

最好的方法是什么?

帮帮我,谢谢。

解决方法

您可以使用 alter table tab drop column col;。但是如果你有一个大表或者PK,FK,检查约束,或者定义在上面的索引,那么你需要小心。 所以,这是我的想法 -

  1. 备份表。
select * into tab_bkp from  old_tab; 
  1. 如果该列有约束,您需要先删除它。
alter table tab drop constraint cons_1;
  1. 从表中删除列。
alter table tab drop column col;
  1. 检查数据。有任何问题,您可以从 tab_bkp 中检索数据。
,

如果您要删除的那一列是您大部分代码的存储位置,那么实际上也可能是一个想法:

  1. 创建一个新表(没有要删除的列)
  2. 将其他列中的数据复制到该新表中
  3. 删除现有表(可能首先删除 FK 和其他约束)
  4. 将新创建的表(带有数据)重命名为旧表名(并重新建立您需要的任何约束)

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