在一条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. SQL 如下:

select  * from  数据库1.dbo.表1

   union all

   select  * from  数据库2.dbo.表1

  union all

  select  * from  数据库3.dbo.表1

3. 第二中情况,多台服务器上的数据库

4.同样的在SQL Server2005中也可以链接到其他的SQL Server数据库,

5. 请参考下列图片:

6. 简单SQL 如下:

下面就可以直接在本地查询远程数据库的表了:

  select * from [server1].[数据库1].[dbo].表1


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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存