MS SQL Server中把一个数据库中的一张表考到另外一个数据库中

现有数据库a和数据库b,数据库a里有表table1,数据库b里有表table2.(转)


现在要把表table1里的记录复制到table2中,不同情况采用不同方法:


1. table1和table2表结构相同


use b


insert into table2 select * from a.dbo.table1


2. table1和table2表结构不相同


use b


insert into table2(c1,c2) select c1,c2 from a.dbo.table1


coolxiaoyi:c1,c2为需要复制的列。


3.
如果还没有创建表table2,可以直接将table1的表结构和记录都复制到数据库b中


use b


select * into table2 from a.dbo.table1


coolxiaoyi:这样做有一个问题,就是有时主外键关系不能复制过去(不知道什么原因),需要在执行完sql语句后自己再设置一下主外键。


4. 注意table2中是否有自增长字段


如果有自增长字段,使用以上sql语句时会报错:仅当使用了列列表并且 IDENTITY_INSERT 为 ON
时,才能为表'table2'中 的标识列指定显式值。


coolxiaoyi:可以先修改table2表,去掉自增长标识,复制完记录后再修改回来。


或者用2.中的sql语句,不复制自增长字段,复制其他字段。

posted on   幻林的地盘  阅读(588)  评论(1编辑  收藏  举报

编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
< 2011年6月 >
29 30 31 1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 1 2
3 4 5 6 7 8 9

导航

统计

点击右上角即可分享
微信分享提示