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


当前回答

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

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

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

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

其他回答

你可以使用链接服务器。

通常,链接服务器被配置为允许数据库引擎执行Transact-SQL语句,其中包含SQL Server的另一个实例或Oracle等其他数据库产品中的表。许多类型的OLE DB数据源可以配置为链接服务器,包括Microsoft Access和Excel。

链接服务器提供以下优势:

能够从SQL Server外部访问数据。 在整个企业的异构数据源上发布分布式查询、更新、命令和事务的能力。 类似地处理不同数据源的能力。

阅读更多关于链接服务器的信息。

按照以下步骤创建链接服务器:

服务器对象->链接服务器->新建链接服务器 提供远程服务器名称。 选择“远程服务器类型”(SQL Server或Other)。 选择安全->使用此安全上下文并提供远程服务器的登录名和密码。 点击OK,你就完成了!!

下面是一个创建链接服务器的简单教程。

OR

您可以使用查询添加链接服务器。

语法:

sp_addlinkedserver [ @server= ] 'server' [ , [ @srvproduct= ] 'product_name' ] 
     [ , [ @provider= ] 'provider_name' ]
     [ , [ @datasrc= ] 'data_source' ] 
     [ , [ @location= ] 'location' ] 
     [ , [ @provstr= ] 'provider_string' ] 
     [ , [ @catalog= ] 'catalog' ] 

阅读更多关于sp_addlinkedserver的信息。

您只需创建链接服务器一次。创建链接服务器后,我们可以这样查询:

select * from LinkedServerName.DatabaseName.OwnerName.TableName

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调用您的表的同义词。您的查询不需要包括任何模式,或不同的数据库名称,只需按惯例调用表名,它就可以工作。

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

试试这个:

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
 select * 
 from [ServerName(IP)].[DatabaseName].[dbo].[TableName]