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

时间:2009-07-17 15:34:43

标签: sql sql-server

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

14 个答案:

答案 0 :(得分:318)

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

Server Objects-->Linked Servers

或者您可以使用sp_addlinkedserver

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

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

请注意,所有者并非总是dbo,因此请务必使用您使用的任何架构替换它。

答案 1 :(得分:86)

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

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

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

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

详细了解Linked Servers

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

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

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

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

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

  5. 点击“确定”即可完成!!

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

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

    语法:

    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
    

答案 2 :(得分:24)

SELECT
        *
FROM
        [SERVER2NAME].[THEDB].[THEOWNER].[THETABLE]

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

答案 3 :(得分:21)

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

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

答案 4 :(得分:15)

这些都是很好的答案,但是这个缺失并且它具有它自己的强大用途。可能它不适合OP想要的东西,但问题很模糊,我觉得其他人可能会找到他们的方式。基本上,您可以使用1个窗口同时针对多个服务器运行查询,具体如下:

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

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

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

答案 5 :(得分: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

答案 6 :(得分: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'

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

第2步:运行查询 例如:

SELECT * FROM [SRV_NAME].your_remote_db_name.dbo.your_table

......那就是它!

语法详细信息:sp_addlinkedserversp_addlinkedsrvlogin

答案 7 :(得分:4)

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

答案 8 :(得分:4)

Server 2008:

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

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

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

我收到错误:

  

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

添加服务器:

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

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

SELECT * FROM [sys].[servers]

答案 9 :(得分:2)

 select * 
 from [ServerName(IP)].[DatabaseName].[dbo].[TableName]

答案 10 :(得分:0)

sp_addlinkedserver('servername')

所以它应该像这样 -

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

答案 11 :(得分:0)

我知道这是一个老问题,但我使用同义词。据推测,查询在数据库服务器A中执行,并在数据库服务器B中查找服务器A上不存在的表。然后在从服务器B调用表的数据库中添加同义词。您的查询不是必须包含任何模式或不同的数据库名称,只需按常规调用表名即可。

没有必要链接服务器,因为每个同义词都是一种链接。

答案 12 :(得分:0)

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

第一台服务器

EXEC sp_addlinkedserver @server='ip,port\instancename'

第二次登录

EXEC sp_addlinkedsrvlogin 'ip,port\instancename', 'false', NULL, 'remote_db_loginname', 'remote_db_pass'

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

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

答案 13 :(得分:0)

@ Super9讲述了使用带有数据提供程序的SQL Server身份验证的OPENDATASOURCE   SQLOLEDB 。我只是在此处发布一个表的代码片段,该表位于正在运行该代码的当前服务器数据库中,而另一个服务器'192.166.41.123'

SELECT top 2 * from dbo.tblHamdoonSoft  tbl1 inner JOIN  
OpenDataSource('SQLOLEDB','Data Source=192.166.41.123;User ID=sa;Password=hamdoonsoft')
.[TestDatabase].[dbo].[tblHamdoonSoft1] tbl2 on tbl1.id = tbl2.id