从大 table 到 delete/drop 列的哪条路
Which way to delete/drop a column from a big table
我的 table 有 119962649 行,大小超过 600 GB。
我想要 delete/drop 一列类型 nvarchar(MAX)
。
哪种方法最好?
帮帮我,谢谢。
您可以使用 alter table tab drop column col;
。但是如果你有一个很大的 table 或 PK,FK,检查约束,或者在上面定义的索引,那么你需要小心。
所以,这是我的想法 -
- 备份 table.
select * into tab_bkp from old_tab;
- 如果该列有约束,您需要先将其删除。
alter table tab drop constraint cons_1;
- 从 table 中删除列。
alter table tab drop column col;
- 检查数据。任何错误,您可以从 tab_bkp.
检索数据
如果您要删除的那一列是存储大部分代码的地方,实际上也可能是一个想法:
- 创建一个新的 table(没有您要删除的那一列)
- 将其他列中的数据复制到新的 table
- 删除现有的 table(可能首先删除 FK 和其他约束)
- 将新创建的 table(带有数据)重命名为旧的 table 名称(并重新建立您需要的任何约束)
我的 table 有 119962649 行,大小超过 600 GB。
我想要 delete/drop 一列类型 nvarchar(MAX)
。
哪种方法最好?
帮帮我,谢谢。
您可以使用 alter table tab drop column col;
。但是如果你有一个很大的 table 或 PK,FK,检查约束,或者在上面定义的索引,那么你需要小心。
所以,这是我的想法 -
- 备份 table.
select * into tab_bkp from old_tab;
- 如果该列有约束,您需要先将其删除。
alter table tab drop constraint cons_1;
- 从 table 中删除列。
alter table tab drop column col;
- 检查数据。任何错误,您可以从 tab_bkp. 检索数据
如果您要删除的那一列是存储大部分代码的地方,实际上也可能是一个想法:
- 创建一个新的 table(没有您要删除的那一列)
- 将其他列中的数据复制到新的 table
- 删除现有的 table(可能首先删除 FK 和其他约束)
- 将新创建的 table(带有数据)重命名为旧的 table 名称(并重新建立您需要的任何约束)