克里斯朵夫·李小白
行驶在蜿蜒曲折的盘山公路上

  今天遇到这样的问题,要从一个数据库中复制一张表的数据到另一个数据库的同名表,以往我的做法就是将脚本文件导出来,然后执行一下,但是这次我试了一下,由于数据太多,导出的脚本有五百多兆,ssms根本运行不了。一番搜索找到了以下解决方案:

-- 代码一
INSERT INTO [database1].[dbo].[table1] ([字段1],[字段2]……)
SELECT [字段1],[字段2]……  FROM  [database2].[dbo].[table2]

  两处的字段要一一对应;如果遇到有id自增的情况,有大神给的解决方法是:

-- 代码二
SET IDENTITY_INSERT [table] ON; -- 开启表中标识列
SET IDENTITY_INSERT [table] OFF; -- 关闭表中标志列

  可在将以上代码二两句分别插在代码一前后,再执行;但是我没有实现,可能是姿势有问题(后来亲测可行),所以我还是用的笨办法,就是执行前先设计表,将id设为不自增,执行完再改成自增。
  其实这种写法也有其他的效果:

-- 同数据库不同表数据复制
INSERT INTO [table1] ([字段1]……)
SELECT ([字段1]……) FROM [table2];

-- 创建新的表同时复制数据
SELECT [字段1]…… INTO new_table FROM old_table;

  记录学习一下,错误的地方欢迎大佬们指正。

posted on 2019-01-16 23:01  smallcode1  阅读(1889)  评论(0)    收藏  举报