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

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

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)

当前回答

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

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

希望能节省很多时间:)

其他回答

我们可以像这样在一个查询中修改多个列:

ALTER TABLE `tblcommodityOHLC`
    CHANGE COLUMN `updated_on` `updated_on` DATETIME NULL DEFAULT NULL AFTER `updated_by`,
    CHANGE COLUMN `delivery_datetime` `delivery_datetime` DATETIME NULL DEFAULT CURRENT_TIMESTAMP AFTER `delivery_status`;

只需以逗号分隔查询。

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

查询:

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

如果你不想自己写整个东西,把所有的列都改成相同的数据类型,这可以让它更容易:

select 'alter table tblcommodityOHLC alter column '+name+ 'NUMERIC(18,0);'
from syscolumns where id = object_id('tblcommodityOHLC ')

您可以复制和粘贴输出作为您的查询

将ALTER COLUMN语句放在括号内,它应该可以工作。

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

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

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