如何从SQL Server中两个不同服务器上的两个不同数据库中选择同一查询中的数据?
当前回答
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]
其他回答
你可以使用链接服务器。
通常,链接服务器被配置为允许数据库引擎执行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
sp_addlinkedserver('servername')
所以它应该是这样的
select * from table1
unionall
select * from [server1].[database].[dbo].[table1]
您正在寻找的是链接服务器。你可以从对象资源管理器树中的以下位置在SSMS中找到它们:
服务器对象——>链接服务器
或者您可以使用sp_addlinkedserver。
你只需要建立一个。一旦你有了这个,你可以像这样调用另一个服务器上的表:
select
*
from
LocalTable,
[OtherServerName].[OtherDB].[dbo].[OtherTable]
注意,所有者并不总是dbo,因此请确保将其替换为您使用的任何模式。
服务器对象——>链接服务器——>新的链接服务器
在链接服务器中写入其他服务器的服务器名称或IP地址,并选择SQL server 在Security中选择(使用此安全上下文) 编写其他服务器的登录名和密码
现在连接,然后使用
Select * from [server name or ip addresses ].databasename.dbo.tblname
我希望上面提到的澄清,已经回答了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 R2中重命名数据库时出错
- 将数据复制到另一个表中
- 如何在SQL中选择表的最后一条记录?
- SQL在Oracle中连接多行列值的查询
- 修改列,添加默认约束
- 在单个查询中计算空值和非空值
- 在存储过程中使用“SET XACT_ABORT ON”有什么好处?
- SQL to LINQ工具
- 如何从一个查询插入多行使用雄辩/流利
- 如何连接列在Postgres选择?
- 有人可以对SQL查询进行版权保护吗?
- 如何知道MySQL表最近一次更新?
- 如何转储一些SQLite3表的数据?
- 如何检查SQL Server文本列是否为空?
- 如何创建一个SQL Server函数“连接”多行从一个子查询到一个单独的分隔字段?