如何从SQL Server中两个不同服务器上的两个不同数据库中选择同一查询中的数据?
当前回答
添加链接服务器的简化解决方案
第一个服务器
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]
其他回答
在一台服务器中为另一台服务器创建链接服务器定义(需要SA来完成此操作),然后使用四部分命名引用它们(参见BOL)。
select *
from [ServerName(IP)].[DatabaseName].[dbo].[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
服务器对象——>链接服务器——>新的链接服务器
在链接服务器中写入其他服务器的服务器名称或IP地址,并选择SQL server 在Security中选择(使用此安全上下文) 编写其他服务器的登录名和密码
现在连接,然后使用
Select * from [server name or ip addresses ].databasename.dbo.tblname
推荐文章
- 在SQL Server 2008 R2中重命名数据库时出错
- 将数据复制到另一个表中
- 如何在SQL中选择表的最后一条记录?
- SQL在Oracle中连接多行列值的查询
- 修改列,添加默认约束
- 在单个查询中计算空值和非空值
- 在存储过程中使用“SET XACT_ABORT ON”有什么好处?
- SQL to LINQ工具
- 如何从一个查询插入多行使用雄辩/流利
- 如何连接列在Postgres选择?
- 有人可以对SQL查询进行版权保护吗?
- 如何知道MySQL表最近一次更新?
- 如何转储一些SQLite3表的数据?
- 如何检查SQL Server文本列是否为空?
- 如何创建一个SQL Server函数“连接”多行从一个子查询到一个单独的分隔字段?