sqlserver复制表结构
今天遇到一个情况,就是复制mssql表的表结构到新表当中,在网上查了一些资料,解决方案如下:
1,select * into 数据库名.dbo.新表名 from 数据库名.dbo.原表名 where 1=0
2,击Oldtable-->所有任务-->生成SQL脚本-->选项-->选中“编写主键、外键、默认值和检查约束脚本”-->设置格式-->只勾选“为每个对象生成CREATE<对象>命令”-->常规-->预览-->然后复制看到SQL语句-->关闭-->单击工具条上的工具-->SQL查询分析器-->粘贴-->修改oldtable为newtable-->然后按F5执行-->完成
3,CREATE TABLE 新表SELECT * FROM 旧表WHERE 1=2或CREATE TABLE 新表LIKE 旧表
经实测。
1,只能复制表字段,字段的备注说明、默认值等是复制不过来的,放弃。
2,生成SQL脚本-->选项,这个选项没找着在哪,放弃。
3,这个是在Oracle上可用,在mssql是报语法错误,放弃。
后来,在MSDN上找到一个解决办法,如下所示,经测试,可用,现分享出来,步骤如下。
复制表
-
请确保您已经连接到要在其中创建表的数据库并在对象资源管理器中选中该数据库。
-
在对象资源管理器中,右键单击“表”,再单击“新建表”。
-
在对象资源管理器中,右键单击要复制的表,再单击“设计”。
-
在现有表中选择列,在“编辑”菜单上单击“复制”。
-
切换回新表并选择第一行。
-
在“编辑”菜单上,单击“粘贴”。
-
在“文件”菜单上,单击“保存 table name”。
-
在“选择名称”对话框中,键入新表的名称并单击“确定”。