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


当前回答

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

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

现在连接,然后使用

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

其他回答

试试这个:

SELECT * FROM OPENROWSET('SQLNCLI', 'Server=YOUR SERVER;Trusted_Connection=yes;','SELECT * FROM Table1') AS a
UNION
SELECT * FROM OPENROWSET('SQLNCLI', 'Server=ANOTHER SERVER;Trusted_Connection=yes;','SELECT * FROM Table1') AS a

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

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

现在连接,然后使用

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

在一台服务器中为另一台服务器创建链接服务器定义(需要SA来完成此操作),然后使用四部分命名引用它们(参见BOL)。

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

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

或者您可以使用sp_addlinkedserver。

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

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

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

SELECT
        *
FROM
        [SERVER2NAME].[THEDB].[THEOWNER].[THETABLE]

您还可以使用链接服务器。链接服务器也可以是其他类型的数据源,比如DB2平台。这是一种尝试从SQL Server TSQL或Sproc调用访问DB2的方法…