当前位置:  开发笔记 > 数据库 > 正文

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

如何解决《如何在不删除查询列的情况下更改列的数据类型?》经验,为你挑选了7个好方法。

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



1> devio..:

MSDN说

ALTER TABLE mytable ALTER COLUMN mycolumn newtype

请注意文章中列出的ALTER COLUMN子句的限制



2> Mark Brittin..:

如果ALTER COLUMN不起作用.

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

听起来像很多工作?实际上,事实并非如此.

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

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

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



3> Pratyay..:
ALTER TABLE [table name] MODIFY COLUMN [column name] datatype



4> capotej..:
ALTER TABLE YourTableNameHere ALTER COLUMN YourColumnNameHere VARCHAR(20)



5> 小智..:

这很简单!只需输入波纹管查询

alter table table_Name alter column column_name datatype

alter table Message alter column message nvarchar(1024);

它会工作愉快的编程



6> Leon Tayson..:
ALTER TABLE YourTableNameHere ALTER COLUMN YourColumnNameHere VARCHAR(20)



7> 小智..:

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

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

推荐阅读
拾味湖
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有