在SQL Server中选择来自两个不同服务器的数据

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

895202 次浏览

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

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

Server Objects-->Linked Servers

或者你可以使用sp_addlinkedserver

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

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

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

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

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

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

  1. 连接服务器:提供比SQL Server复制提供的更广泛的数据源访问
  2. 连接服务器:连接复制不支持或需要临时访问的数据源
  3. 连接服务器:性能优于OPENDATASOURCE或OPENROWSET
  4. OPENDATASOURCEOPENROWSET函数: 方便在临时基础上从数据源检索数据。 OPENROWSET也有BULK功能,可能需要/可能不需要格式文件fiddley
  5. OPENQUERY:不支持变量
  6. 所有是T-SQL解决方案。相对容易实现和设置
  7. 所有依赖于源和目的地之间的连接,这可能会影响性能和可伸缩性
sp_addlinkedserver('servername')

所以它应该是这样的

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

试试这个:

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

你可以使用链接服务器。

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

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

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

阅读更多关于< >强链接服务器< / >强

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

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

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

  3. 选择“远程服务器类型”(SQL Server或Other)。

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

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

这里<强> < / >强是一个创建链接服务器的简单教程。

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

语法:

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

添加服务器。

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

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

SELECT * FROM [sys].[servers]

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

在链接服务器中写入其他服务器的服务器名或IP地址,并选择SQL server 在Security中选择(使用此安全上下文) 为其他服务器写登录名和密码

现在连接,然后使用

Select * from [server name or ip addresses ].databasename.dbo.tblname
 select *
from [ServerName(IP)].[DatabaseName].[dbo].[TableName]

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

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

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

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

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

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

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

远程IP db连接的扩展答案:

步骤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步:运行查询 例如:< / p >

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

…就是这样!

语法细节:sp_addlinkedserversp_addlinkedsrvlogin

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

第一个服务器

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

第二次登录

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

执行从链接到本地db的查询

INSERT INTO Tbl (Col1, Col2, Col3)
SELECT Col1, Col2, Col3
FROM [ip,port\instancename].[linkedDBName].[linkedTblSchema].[linkedTblName]
@Super9讲述了OPENDATASOURCE使用数据提供者的SQL Server身份验证 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

我希望上面提到的澄清,已经回答了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_PROVIDERNAMESRV_PRODUCTSRV_DATASOURCE等填充为默认值。 通过这样做,我们必须在查询中的4部分表地址中写入IP或PC域名(下面的示例)。当被链接的服务器将没有默认端口或实例,地址将看起来类似于192.168.1.11,1430192.168.1.11,1430\MSSQLSERVER2019时,这可能会更令人讨厌或可读性较差

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

exec sp_addlinkedserver
@server='ReadSrv1',
@srvproduct='SQL Server',
@provider='SQLNCLI',
@datasrc='192.168.1.11,1430\MSSQLSERVER2019'
但是当你执行查询时,下面的错误将显示- You cannot specify a provider or any properties for product 'SQL Server'. 如果我们保持服务器产品属性值为空''或任何其他值,查询将成功执行

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

EXEC sp_addlinkedsrvlogin @rmtsrvname = 'ReadSrv1', @useself = 'false', @locallogin = NULL, @rmtuser = 'sa', @rmtpassword = 'LinkedServerPasswordForSA'
最后,使用带有4部分地址的链接服务器,语法为-
[ServerName].[DatabaseName].[Schema].[ObjectName]
例子——< / p >
SELECT TOP 100 t.* FROM ReadSrv1.AppDB.dbo.ExceptionLog t
  • 列出已存在的链接服务器执行:
    exec sp_linkedservers < / >
  • 删除链接服务器执行:
    . sh exec sp_dropserver @server = 'ReadSrv1', @droplogins='droplogins'(删除登录)OR
    exec sp_dropserver @server = 'ReadSrv1', @droplogins='NULL' (keep login)