如何在不删除查询列的情况下更改列的数据类型?

时间:2009-01-03 09:47:03

标签: sql-server

我有一个具有数据类型的列:datetime。但现在我想将其转换为数据类型varchar。我可以在不删除列的情况下更改数据类型吗?如果是,那么请解释一下如何?

15 个答案:

答案 0 :(得分:88)

MSDN says

ALTER TABLE mytable ALTER COLUMN mycolumn newtype

请注意文章

中列出的ALTER COLUMN子句的限制

答案 1 :(得分:27)

如果ALTER COLUMN不起作用。

更改列失败并不罕见,因为它无法进行所需的转换。在这种情况下,解决方案是创建一个虚表TableName_tmp,使用批量Insert命令中的专用转换复制数据,删除原始表,并将tmp表重命名为原始表的名称。您必须删除并重新创建外键约束,并且为了提高性能,您可能希望在填充tmp表后创建键。

听起来像很多工作?实际上,它不是。

如果您使用的是SQL Server,则可以让SQL Server Management Studio为您完成工作!

打开表格结构(右键单击表格并选择“修改”)并进行所有更改(如果列转换是非法的,只需添加新列 - 您将立即修补它)。接下来,右键单击“修改”窗口的背景,然后选择“生成更改脚本”。在出现的窗口中,您可以将更改脚本复制到剪贴板。

取消修改(毕竟,您将要测试脚本),然后将脚本粘贴到新的查询窗口中。根据需要进行修改(例如,在从tmp表声明中删除字段时添加转换),现在您已经拥有了进行转换所需的脚本。

答案 2 :(得分:12)

ALTER TABLE [table name] MODIFY COLUMN [column name] datatype

答案 3 :(得分:10)

ALTER TABLE YourTableNameHere ALTER COLUMN YourColumnNameHere VARCHAR(20)

答案 4 :(得分:7)

ALTER TABLE YourTableNameHere ALTER COLUMN YourColumnNameHere VARCHAR(20)

答案 5 :(得分:7)

很简单!只需键入下面的查询

  

alter table table_Name alter column column_name datatype

     

<强> alter table Message alter column message nvarchar(1024);

它会起作用 快乐编程

答案 6 :(得分:6)

使用SQL Server 2008及更多版本,使用此查询:

ALTER TABLE [RecipeInventorys] ALTER COLUMN [RecipeName] varchar(550)

答案 7 :(得分:2)

这项工作适用于postgresql 9.0.3

 alter table [table name] ALTER COLUMN [column name] TYPE [character varying];

http://www.postgresql.org/docs/8.0/static/sql-altertable.html

答案 8 :(得分:1)

ALTER TABLE [table_name] ALTER COLUMN [column_name] varchar(150)

答案 9 :(得分:1)

ALTER TABLE YourTableNameHere ALTER COLUMN YourColumnNameHere VARCHAR(20)这非常适合更改为数据类型

答案 10 :(得分:0)

ORACLE - 更改表table_name modify(column_name new_DataType);

答案 11 :(得分:0)

ALTER TABLE yourtable MODIFY COLUMN yourcolumn数据类型

答案 12 :(得分:-1)

ALTER TABLE table_name
MODIFY (column_name data_type);

答案 13 :(得分:-2)

ALTER tablename MODIFY columnName newColumnType

我不确定如何处理从datetime到varchar的更改,因此您可能需要重命名该列,添加一个具有旧名称和正确数据类型(varchar)的新列,然后编写更新查询从旧的填充新列。

http://www.1keydata.com/sql/sql-alter-table.html

答案 14 :(得分:-4)

alter table [table name] remove [present column name] to [new column name.