我想编写一个SQL命令,在一个ALTER table语句中删除单个表中的多个列。
从MSDN的ALTER TABLE文档…
DROP {[CONSTRAINT] constraint_name | COLUMN column_name}
指定从表中删除constraint_name或column_name。如果兼容级别为65或更早,则不允许使用DROP COLUMN。可以列出多个列和约束。
它说可以在语句中列出多个列,但语法没有显示可选的逗号或任何暗示语法的东西。
我应该如何写我的SQL在一个语句中删除多个列(如果可能的话)?
对于SQL Server:
ALTER TABLE TableName
DROP COLUMN Column1, Column2;
语法是
DROP { [ CONSTRAINT ] constraint_name | COLUMN column } [ ,...n ]
MySQL:
ALTER TABLE TableName
DROP COLUMN Column1,
DROP COLUMN Column2;
或者像这样:
ALTER TABLE TableName
DROP Column1,
DROP Column2;
COLUMN这个词是可选的,可以省略,除了RENAME COLUMN(用来区分列重命名操作和RENAME表重命名操作)。更多信息请点击这里。
总结
Oracle:
ALTER TABLE table_name DROP (column_name1, column_name2);
MS SQL Server:
ALTER TABLE table_name DROP COLUMN column_name1, column_name2
MySQL:
ALTER TABLE table_name DROP column_name1, DROP column_name2;
PostgreSQL
ALTER TABLE table_name DROP COLUMN column_name1, DROP COLUMN column_name2;
请注意
DROP COLUMN不会物理删除某些DBMS的数据。例如,MS SQL。对于固定长度类型(int, numeric, float, datetime, uniqueidentifier等),即使在删除列后添加的记录也会占用空间。为了消除浪费的空间做ALTER TABLE…重建。
Microsoft为删除ALTER语句中的列部分指定的语法如下所示
DROP
{
[ CONSTRAINT ]
{
constraint_name
[ WITH
( <drop_clustered_constraint_option> [ ,...n ] )
]
} [ ,...n ]
| COLUMN
{
column_name
} [ ,...n ]
} [ ,...n ]
注意[,…N]出现在列名之后和整个drop子句的末尾。这意味着有两种方法可以删除多个列。你可以这样做:
ALTER TABLE TableName
DROP COLUMN Column1, Column2, Column3
或者这个
ALTER TABLE TableName
DROP
COLUMN Column1,
COLUMN Column2,
COLUMN Column3
如果你想把删除列和删除约束结合起来,这第二个语法是有用的:
ALTER TBALE TableName
DROP
CONSTRAINT DF_TableName_Column1,
COLUMN Column1;
When dropping columns SQL Sever does not reclaim the space taken up by the columns dropped. For data types that are stored inline in the rows (int for example) it may even take up space on the new rows added after the alter statement. To get around this you need to create a clustered index on the table or rebuild the clustered index if it already has one. Rebuilding the index can be done with a REBUILD command after modifying the table. But be warned this can be slow on very big tables. For example:
ALTER TABLE Test
REBUILD;