如何从SQL Server中两个不同服务器上的两个不同数据库中选择同一查询中的数据?
当前回答
select *
from [ServerName(IP)].[DatabaseName].[dbo].[TableName]
其他回答
我希望上面提到的澄清,已经回答了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'(保持登录)
服务器对象——>链接服务器——>新的链接服务器
在链接服务器中写入其他服务器的服务器名称或IP地址,并选择SQL server 在Security中选择(使用此安全上下文) 编写其他服务器的登录名和密码
现在连接,然后使用
Select * from [server name or ip addresses ].databasename.dbo.tblname
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]
这些都是很好的答案,但这一个是缺失的,它有自己强大的用途。这可能不符合OP的要求,但问题很模糊,我觉得其他人可能会找到他们的方式。基本上你可以使用一个窗口同时对多个服务器运行查询,下面是如何做到的:
在SSMS中打开注册服务器并在本地服务器组下创建一个新服务器组。
在该组下,为您希望查询的每个服务器创建新服务器注册。如果DB名称不同,请确保在属性中为每个DB名称设置默认值。
现在回到第一步中创建的Group,右键单击并选择New Query。将打开一个新的查询窗口,您运行的任何查询都将在组中的每个服务器上执行。结果显示在一个单独的数据集中,其中有一个额外的列名,表示该记录来自哪个服务器。如果您使用状态栏,您将注意到服务器名称被多个替换。
sp_addlinkedserver('servername')
所以它应该是这样的
select * from table1
unionall
select * from [server1].[database].[dbo].[table1]
推荐文章
- GROUP BY with MAX(DATE)
- 删除id与其他表不匹配的sql行
- 等价的限制和偏移SQL Server?
- 如何从SQL Server中的字符串中剥离所有非字母字符?
- 为什么我不能在DELETE语句中使用别名?
- 在SQL Server Management Studio中保存带有标题的结果
- "where 1=1"语句
- 如何选择一个记录和更新它,与一个单一的查询集在Django?
- 多语句表值函数vs内联表值函数
- 如何从Oracle的表中获取列名?
- NOLOCK提示在SELECT语句中的作用
- SQL OVER()子句-它什么时候有用,为什么有用?
- 如果字段在MySQL中为空,则返回0
- 检查SQL Server登录是否已经存在
- 我如何使用ROW_NUMBER()?