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


当前回答

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

其他回答

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

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

或者您可以使用sp_addlinkedserver。

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

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

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

你可以使用链接服务器。

通常,链接服务器被配置为允许数据库引擎执行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

正如@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_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'(保持登录)

我在连接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:运行查询 例如:

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

...就是这样!

语法详细信息:sp_addlinkedserver和sp_addlinkedsrvlogin