如何从SQL Server中两个不同服务器上的两个不同数据库中选择同一查询中的数据?
当前回答
你可以使用链接服务器。
通常,链接服务器被配置为允许数据库引擎执行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
SELECT
*
FROM
[SERVER2NAME].[THEDB].[THEOWNER].[THETABLE]
您还可以使用链接服务器。链接服务器也可以是其他类型的数据源,比如DB2平台。这是一种尝试从SQL Server TSQL或Sproc调用访问DB2的方法…
在一台服务器中为另一台服务器创建链接服务器定义(需要SA来完成此操作),然后使用四部分命名引用它们(参见BOL)。
我知道这是一个老问题,但我使用同义词。假设查询在数据库服务器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:运行查询 例如:
SELECT * FROM [SRV_NAME].your_remote_db_name.dbo.your_table
...就是这样!
语法详细信息:sp_addlinkedserver和sp_addlinkedsrvlogin
推荐文章
- 在SQL Server 2008 R2中重命名数据库时出错
- 将数据复制到另一个表中
- 如何在SQL中选择表的最后一条记录?
- SQL在Oracle中连接多行列值的查询
- 修改列,添加默认约束
- 在单个查询中计算空值和非空值
- 在存储过程中使用“SET XACT_ABORT ON”有什么好处?
- SQL to LINQ工具
- 如何从一个查询插入多行使用雄辩/流利
- 如何连接列在Postgres选择?
- 有人可以对SQL查询进行版权保护吗?
- 如何知道MySQL表最近一次更新?
- 如何转储一些SQLite3表的数据?
- 如何检查SQL Server文本列是否为空?
- 如何创建一个SQL Server函数“连接”多行从一个子查询到一个单独的分隔字段?