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

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

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

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

  可在将以上代码二两句分别插在代码一前后,再执行;但是我没有实现,可能是姿势有问题,所以我还是用的笨办法,就是执行前先设计表,将id设为不自增,执行完再改成自增。

  其实这种写法也有其他的效果:

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

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

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

版权声明:本文为99ll原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/99ll/p/10279906.html