在一条SQL语句中同时对两个数据库中的不同表进行 *** 作,有什么好的解决方法吗?

在一条SQL语句中同时对两个数据库中的不同表进行 *** 作,有什么好的解决方法吗?,第1张

1.如果是同一服务器

假设 另一个数据库名为'数据库B',并且当然用户对两个数据库都有对应权限

select into [table] from [数据库B].[所有者].[表名]

2.如果不在同一服务器

select into [table] from opendatasource('sqloledb','data source=服务器名或IPuser id=登陆名password=口令').数据库B.表名

在执行的时候,要注意两个表的标示要写完整:数据库名.用户名.表名

例如:

insert into db1.yonghu1.bm

select * from db2.yonghu2.bm

db1和db2是数据库名,yonghu1和yonghu2是数据库的用户名,bm是表名。

1、首先就是创建几个没有任何关系的表,但是注意,你在将要作为外键表的表上必须使用与将要作为主键表的数据类型相同。

2、将能唯一标识的那一行设置为主键,其他表类似。

3、接下来添加关系,如下图。

4、拖动需要添加的关系,直接看图。

5、关联完成,如图。

1.在同一台服务器同一个实例上的两个数据库的话,在表名字名字加上数据库名和架构名;如查询a数据库dbo架构下的mm表中的数据:select *from a.dbo.mm\x0d\x0a2.在不同服务器上或者在不同实例上的两个数据库:\x0d\x0aexec sp_addlinkedserver 'sv','','sqloledb','ip地址'\x0d\x0aexec sp_addlinkedsvlogin 'sv','false',null,'sa','pwd'\x0d\x0ago\x0d\x0aselect *from sv.a.dbo.mm


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/6803855.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-28
下一篇 2023-03-28

发表评论

登录后才能评论

评论列表(0条)

保存