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


当前回答

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

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

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

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

其他回答

试试这个:

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
sp_addlinkedserver('servername')

所以它应该是这样的

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

跨2个不同的数据库进行查询是一种分布式查询。以下是一些技巧及其优缺点:

Linked servers: Provide access to a wider variety of data sources than SQL Server replication provides Linked servers: Connect with data sources that replication does not support or which require ad hoc access Linked servers: Perform better than OPENDATASOURCE or OPENROWSET OPENDATASOURCE and OPENROWSET functions: Convenient for retrieving data from data sources on an ad hoc basis. OPENROWSET has BULK facilities as well that may/may not require a format file which might be fiddley OPENQUERY: Doesn't support variables All are T-SQL solutions. Relatively easy to implement and set up All are dependent on connection between source and destionation which might affect performance and scalability

2008年服务器:

当在SSMS中连接到server1时。DB1和try:

SELECT  * FROM
[server2].[DB2].[dbo].[table1]

正如其他人指出的那样,如果它不起作用,那是因为服务器没有链接。

我得到了错误:

在sys.servers中找不到服务器DB2。验证是否正确 设置服务器名。必要时,执行存储过程 Sp_addlinkedserver将服务器添加到sys.servers。

添加服务器。

引用:使用sp_addlinkedserver添加服务器 Link:[1]:使用sp_addlinkedserver添加服务器

看看你的系统里有什么。服务器只是查询它:

SELECT * FROM [sys].[servers]

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

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