SQL server 通过SQL语句实现表数据的复制(可跨库)


  今天遇到这样的问题,要从一个数据库中复制一张表的数据到另一个数据库的同名表,以往我的做法就是将脚本文件导出来,然后执行一下,但是这次我试了一下,由于数据太多,导出的脚本有五百多兆,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;

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


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM