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


当前回答

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

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

现在连接,然后使用

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

其他回答

这些都是很好的答案,但这一个是缺失的,它有自己强大的用途。这可能不符合OP的要求,但问题很模糊,我觉得其他人可能会找到他们的方式。基本上你可以使用一个窗口同时对多个服务器运行查询,下面是如何做到的:

在SSMS中打开注册服务器并在本地服务器组下创建一个新服务器组。

在该组下,为您希望查询的每个服务器创建新服务器注册。如果DB名称不同,请确保在属性中为每个DB名称设置默认值。

现在回到第一步中创建的Group,右键单击并选择New Query。将打开一个新的查询窗口,您运行的任何查询都将在组中的每个服务器上执行。结果显示在一个单独的数据集中,其中有一个额外的列名,表示该记录来自哪个服务器。如果您使用状态栏,您将注意到服务器名称被多个替换。

sp_addlinkedserver('servername')

所以它应该是这样的

select * from table1
unionall
select * from [server1].[database].[dbo].[table1]

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

在链接服务器中写入其他服务器的服务器名称或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

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