如何从SQL Server中两个不同服务器上的两个不同数据库中选择同一查询中的数据?


当前回答

正如@Super9所说的,OPENDATASOURCE使用数据提供者的SQL Server身份验证 SQLOLEDB . 我只是在这里发布一个代码片段,一个表是在当前服务器数据库中运行的代码,另一个在其他服务器'192.166.41.123'中

SELECT top 2 * from dbo.tblHamdoonSoft  tbl1 inner JOIN  
OpenDataSource('SQLOLEDB','Data Source=192.166.41.123;User ID=sa;Password=hamdoonsoft')
.[TestDatabase].[dbo].[tblHamdoonSoft1] tbl2 on tbl1.id = tbl2.id

其他回答

正如@Super9所说的,OPENDATASOURCE使用数据提供者的SQL Server身份验证 SQLOLEDB . 我只是在这里发布一个代码片段,一个表是在当前服务器数据库中运行的代码,另一个在其他服务器'192.166.41.123'中

SELECT top 2 * from dbo.tblHamdoonSoft  tbl1 inner JOIN  
OpenDataSource('SQLOLEDB','Data Source=192.166.41.123;User ID=sa;Password=hamdoonsoft')
.[TestDatabase].[dbo].[tblHamdoonSoft1] tbl2 on tbl1.id = tbl2.id

添加链接服务器的简化解决方案

第一个服务器

EXEC sp_addlinkedserver @server='ip,port\instancename'

第二次登录

EXEC sp_addlinkedsrvlogin 'ip,port\instancename', 'false', NULL, 'remote_db_loginname', 'remote_db_pass'

执行从链接到本地db的查询

INSERT INTO Tbl (Col1, Col2, Col3)
SELECT Col1, Col2, Col3
FROM [ip,port\instancename].[linkedDBName].[linkedTblSchema].[linkedTblName]

您正在寻找的是链接服务器。你可以从对象资源管理器树中的以下位置在SSMS中找到它们:

服务器对象——>链接服务器

或者您可以使用sp_addlinkedserver。

你只需要建立一个。一旦你有了这个,你可以像这样调用另一个服务器上的表:

select
    *
from
    LocalTable,
    [OtherServerName].[OtherDB].[dbo].[OtherTable]

注意,所有者并不总是dbo,因此请确保将其替换为您使用的任何模式。

服务器对象——>链接服务器——>新的链接服务器

在链接服务器中写入其他服务器的服务器名称或IP地址,并选择SQL server 在Security中选择(使用此安全上下文) 编写其他服务器的登录名和密码

现在连接,然后使用

Select * from [server name or ip addresses ].databasename.dbo.tblname

我知道这是一个老问题,但我使用同义词。假设查询在数据库服务器A中执行,并在数据库服务器B中查找服务器A上不存在的表,然后在数据库中添加从服务器B调用您的表的同义词。您的查询不需要包括任何模式,或不同的数据库名称,只需按惯例调用表名,它就可以工作。

没有必要链接服务器,因为同义词是说,某种链接。