我需要更改表中几个列的数据类型。

对于单个列,下面的工作很好:

ALTER TABLE tblcommodityOHLC
ALTER COLUMN
    CC_CommodityContractID NUMERIC(18,0) 

但是如何在一条语句中修改多个列呢?以下选项无效:

ALTER TABLE tblcommodityOHLC
ALTER COLUMN
    CC_CommodityContractID NUMERIC(18,0), 
    CM_CommodityID NUMERIC(18,0)

当前回答

如果我正确理解了你的问题,你可以使用下面提到的查询在一个表中添加多个列。

查询:

Alter table tablename add (column1 dataype, column2 datatype);

其他回答

这是不可能的。你需要一个一个地做。 你可以:

创建一个临时表,其中包含已修改的列 复制数据 删除原来的表(请仔细检查!) 将临时表重命名为原来的名称

在一条ALTER TABLE语句中执行多个ALTER COLUMN操作是不可能的。

在这里查看ALTER TABLE语法

您可以执行多个ADD或多个DROP COLUMN,但只能执行一个ALTER 列。

-- create temp table 
CREATE TABLE temp_table_alter
(
column_name varchar(255)    
);

-- insert those coulmns in temp table for which we nee to alter size of columns 
INSERT INTO temp_table_alter (column_name) VALUES ('colm1');
INSERT INTO temp_table_alter (column_name) VALUES ('colm2');
INSERT INTO temp_table_alter (column_name) VALUES ('colm3');
INSERT INTO temp_table_alter (column_name) VALUES ('colm4');

DECLARE @col_name_var varchar(255);
DECLARE alter_table_cursor CURSOR FOR
select column_name from temp_table_alter ;

OPEN alter_table_cursor
FETCH NEXT FROM alter_table_cursor INTO @col_name_var
WHILE @@FETCH_STATUS = 0
 BEGIN

 PRINT('ALTER COLUMN ' + @col_name_var);
 EXEC ('ALTER TABLE Original-table  ALTER COLUMN ['+ @col_name_var + '] DECIMAL(11,2);')

 FETCH NEXT FROM alter_table_cursor INTO @col_name_var
 END

CLOSE alter_table_cursor
DEALLOCATE alter_table_cursor

-- at the end drop temp table
drop table temp_table_alter;

下面的解决方案不是一个单独的语句来修改多个列,但是,是的,它使生活变得简单:

生成一个表的CREATE脚本。 第一行用ALTER TABLE [TableName] ALTER COLUMN替换CREATE TABLE 从列表中删除不需要的列。 根据需要更改列数据类型。 执行Find and Replace…,如下所示: 发现:空, 替换为:NULL;修改表的列 点击替换按钮。 运行脚本。

希望能节省很多时间:)

正如其他人回答的那样,您需要多个ALTER TABLE语句。 试一试:

ALTER TABLE tblcommodityOHLC alter column CC_CommodityContractID NUMERIC(18,0);
ALTER TABLE tblcommodityOHLC alter column CM_CommodityID NUMERIC(18,0);