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


当前回答

我希望上面提到的澄清,已经回答了OP最初的问题。我只想添加一个代码片段,用于将SQL Server添加为链接服务器。

在最基本的情况下,我们可以简单地将SQL Server添加为一个链接服务器,通过执行sp_addlinkedserver,只带一个参数@server,即。

-- using IP address
exec sp_addlinkedserver @server='192.168.1.11' 
-- PC domain name 
exec sp_addlinkedserver @server='DESKTOP-P5V8JTN'

SQL Server会自动将SRV_PROVIDERNAME, SRV_PRODUCT, SRV_DATASOURCE等填充为默认值。 通过这样做,我们必须在查询中的4部分表地址中写入IP或PC域名(下面的示例)。当链接的服务器没有默认端口或实例时,这可能更令人讨厌或可读性较差,地址将类似于192.168.1.11,1430或192.168.1.11,1430\MSSQLSERVER2019。

因此,为了保持4部分地址的简短和可读,我们可以为服务器添加一个别名,而不是通过指定以下其他参数的完整地址-

exec sp_addlinkedserver
    @server='ReadSrv1',
    @srvproduct='SQL Server',
    @provider='SQLNCLI',
    @datasrc='192.168.1.11,1430\MSSQLSERVER2019'

但当您执行查询时,将显示以下错误-您无法为产品“SQL Server”指定提供程序或任何属性。 如果我们保持服务器产品属性值为空”或任何其他值,查询将成功执行。

下一步,通过执行以下查询-登录到远程链接服务器

EXEC sp_addlinkedsrvlogin @rmtsrvname = 'ReadSrv1', @useself = 'false', @locallogin = NULL, @rmtuser = 'sa', @rmtpassword = 'LinkedServerPasswordForSA'

最后,使用带有4部分地址的链接服务器,语法为- [ServerName]。[数据库名]。[模式]。[ObjectName] 的例子,

SELECT TOP 100 t.* FROM ReadSrv1.AppDB.dbo.ExceptionLog t

列出已存在的链接服务器执行: exec sp_linkedservers 删除一个链接服务器执行: exec sp_dropserver @server =' ReadSrv1', @droplogins='droplogins'(删除登录)或 exec sp_dropserver @server =' ReadSrv1', @droplogins='NULL'(保持登录)

其他回答

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

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

或者您可以使用sp_addlinkedserver。

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

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

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

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

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

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

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

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

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]
SELECT
        *
FROM
        [SERVER2NAME].[THEDB].[THEOWNER].[THETABLE]

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