从SQL Server中的两个不同服务器中选择数据

344 sql sql-server

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

Eri*_*ric 335

是的你可以.

我想你是怎么回事,所以我会回答这个问题.

您正在寻找的是链接服务器.您可以从对象资源管理器树中的以下位置访问SSMS:

Server Objects-->Linked Servers

或者您可以使用sp_addlinkedserver.

你只需要设置一个.一旦你有了,你就可以在另一台服务器上调用一个表,如下所示:

select
    *
from
    LocalTable,
    [OtherServerName].[OtherDB].[dbo].[OtherTable]
Run Code Online (Sandbox Code Playgroud)

请注意,所有者并非总是dbo如此,因此请确保使用您使用的任何架构替换它.

  • 没有链接服务器我们可以做到吗? (10认同)
  • @TsahiAsher - 当您连接到服务器时,Server Objects是对象资源管理器树中的文件夹. (9认同)
  • @Eric,SSMS中的服务器对象在哪里? (4认同)
  • 如果未知,您还可以省略架构以使用默认值.例如`[OtherServerName].[OtherDB] .. [OtherTable]`但是如果已知,最好包含它. (2认同)

Rag*_*ull 88

您可以使用链接服务器执行此操作.

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

链接服务器具有以下优势:

  • 能够从SQL Server外部访问数据.
  • 能够在整个企业中的异构数据源上发布分布式查询,更新,命令和事务.
  • 能够以类似方式处理各种数据源.

了解更多关于链接服务器.

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

  1. 服务器对象 - >链接服务器 - >新链接服务器

  2. 提供远程服务器名称.

  3. 选择"远程服务器类型"(SQL Server或其他).

  4. 选择安全性 - >使用此安全上下文创建,并提供远程服务器的登录名和密码.

  5. 点击OK,你就完成了!!

是一个用于创建链接服务器的简单教程.

要么

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

句法:

sp_addlinkedserver [ @server= ] 'server' [ , [ @srvproduct= ] 'product_name' ] 
     [ , [ @provider= ] 'provider_name' ]
     [ , [ @datasrc= ] 'data_source' ] 
     [ , [ @location= ] 'location' ] 
     [ , [ @provstr= ] 'provider_string' ] 
     [ , [ @catalog= ] 'catalog' ] 
Run Code Online (Sandbox Code Playgroud)

阅读有关sp_addlinkedserver的更多信息.

您只需创建一次链接服务器.创建链接服务器后,我们可以按如下方式查询:

select * from LinkedServerName.DatabaseName.OwnerName.TableName
Run Code Online (Sandbox Code Playgroud)

  • 如果您在使用 sp_addlinkedserver 时遇到问题,这里有一点提示。在对话框中创建服务器 - 确保它正常工作 - 然后右键单击连接并选择 scrip[t 链接服务器 AS create (2认同)

RSo*_*erg 25

SELECT
        *
FROM
        [SERVER2NAME].[THEDB].[THEOWNER].[THETABLE]
Run Code Online (Sandbox Code Playgroud)

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

  • 确认这在我的环境中失败,错误说我需要使用addlinkedserver (3认同)
  • 这种方法会一直有效吗?什么情况可能会失败? (2认同)

sup*_*er9 22

查询两个不同的数据库是分布式查询.以下是一些技术列表以及优缺点:

  1. 链接服务器:提供对SQL Server复制提供的各种数据源的访问
  2. 链接服务器:连接复制不支持或需要临时访问的数据源
  3. 链接服务器:比OPENDATASOURCE或OPENROWSET表现更好
  4. OPENDATASOURCEOPENROWSET功能:方便从临时数据源检索数据.OPENROWSET也有BULK设施,可能/可能不需要格式文件,可能是fiddley
  5. OPENQUERY:不支持变量
  6. 所有都是T-SQL解决方案.相对容易实现和设置
  7. 所有这些都依赖于源和destion之间的连接,这可能会影响性能和可伸缩性


Pau*_*aul 15

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

在SSMS中打开已注册的服务器并在本地服务器组下创建新的服务器组.

在此组下,为要查询的每个服务器创建新服务器注册.如果数据库名称不同,请确保为属性中的每个名称设置默认值.

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

  • 这似乎假设查询在所有数据库上使用相同的表。(这对于标准表(如sys.tables)很好,但对定制表(如dbo.mycustomers)不太可能) (2认同)
  • @Kross你有点可以。创建一个 #output 表,根据 @@SERVERNAME 执行逻辑并将数据填充到 #output 中,然后通过选择结束它。我做了类似的事情来从具有不同级别/信息列的 SQL2000 和 SQL2008R2 机器的混合查询日志信息,但我使用的是服务器版本变量而不是@@SERVERNAME。 (2认同)

小智 14

试试这个:

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
Run Code Online (Sandbox Code Playgroud)


小智 6

服务器2008:

当在 SSMS 中连接到 server1.DB1 并尝试:

SELECT  * FROM
[server2].[DB2].[dbo].[table1]
Run Code Online (Sandbox Code Playgroud)

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

我收到错误:

在 sys.servers 中找不到服务器 DB2。验证是否指定了正确的服务器名称。如有必要,执行存储过程 sp_addlinkedserver 将服务器添加到 sys.servers。

添加服务器:

参考:使用 sp_addlinkedserver 添加服务器链接:[1]:使用 sp_addlinkedserver 添加服务器

要查看 sys.servers 中的内容,只需查询它:

SELECT * FROM [sys].[servers]
Run Code Online (Sandbox Code Playgroud)


Mar*_*rcM 6

我有同样的问题将SQL_server 2008连接到远程服务器中托管的SQL_server 2016.其他答案对我来说并不直截了当.我在这里编写我的调整解决方案,因为我认为它可能对其他人有用.

远程IP数据库连接的扩展答案:

第1步:链接服务器

EXEC sp_addlinkedserver @server='SRV_NAME',
   @srvproduct=N'',
   @provider=N'SQLNCLI',   
   @datasrc=N'aaa.bbb.ccc.ddd';

EXEC sp_addlinkedsrvlogin 'SRV_NAME', 'false', NULL, 'your_remote_db_login_user', 'your_remote_db_login_password'
Run Code Online (Sandbox Code Playgroud)

......这SRV_NAME是一个发明的名字.我们将使用它从我们的查询中引用远程服务器.aaa.bbb.ccc.ddd是托管SQLserver DB的远程服务器的IP地址.

第2步:运行查询 例如:

SELECT * FROM [SRV_NAME].your_remote_db_name.dbo.your_table
Run Code Online (Sandbox Code Playgroud)

......就是这样!

语法详细信息:sp_addlinkedserversp_addlinkedsrvlogin


irf*_*dar 6

添加链接服务器的简化解决方案

第一台服务器

EXEC sp_addlinkedserver @server='ip,port\instancename'
Run Code Online (Sandbox Code Playgroud)

第二次登录

EXEC sp_addlinkedsrvlogin 'ip,port\instancename', 'false', NULL, 'remote_db_loginname', 'remote_db_pass'
Run Code Online (Sandbox Code Playgroud)

从链接到本地​​数据库执行查询

INSERT INTO Tbl (Col1, Col2, Col3)
SELECT Col1, Col2, Col3
FROM [ip,port\instancename].[linkedDBName].[linkedTblSchema].[linkedTblName]
Run Code Online (Sandbox Code Playgroud)


RBa*_*ung 4

在一台服务器中创建到另一台服务器的链接服务器定义(您需要 SA 来执行此操作),然后只需使用 4 部分命名来引用它们(请参阅 BOL)。