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


当前回答

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

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

或者您可以使用sp_addlinkedserver。

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

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

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

其他回答

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

第一个服务器

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]

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

Linked servers: Provide access to a wider variety of data sources than SQL Server replication provides Linked servers: Connect with data sources that replication does not support or which require ad hoc access Linked servers: Perform better than OPENDATASOURCE or OPENROWSET OPENDATASOURCE and OPENROWSET functions: Convenient for retrieving data from data sources on an ad hoc basis. OPENROWSET has BULK facilities as well that may/may not require a format file which might be fiddley OPENQUERY: Doesn't support variables All are T-SQL solutions. Relatively easy to implement and set up All are dependent on connection between source and destionation which might affect performance and scalability

你可以使用链接服务器。

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

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]

正如@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