如何在SQL中测试链接服务器连接

问题描述 投票:4回答:1

我需要编写一个过程来从几个远程服务器收集数据,

我使用链接服务器和OPENQUERY从服务器收集数据,但有时我失去了与某些服务器的连接,或者我根本无法连接它们(例如远程服务器处于脱机状态) - 并且在这些情况下OPENQUERY会导致超时。

所以我想首先检查链接服务器连接,然后如果它成功运行查询,如果不是只是移动到下一个远程服务器。

我试图将OPENQUERY置于TRY - CATCH但它仍然返回我超时错误,sp_testlinkedserver程序也返回了我超时错误。

我真的很感激任何帮助。

sql tsql connection linked-server openquery
1个回答
15
投票

您可以使用以下脚本

https://web.archive.org/web/20190201090243/https://blogs.msdn.microsoft.com/sqltips/2005/06/07/test-linked-server-connection-settings/

declare @srvr nvarchar(128), @retval int;
set @srvr = 'my_linked_srvr';
begin try
    exec @retval = sys.sp_testlinkedserver @srvr;
end try
begin catch
    set @retval = sign(@@error);
end catch;
if @retval <> 0
  raiserror('Unable to connect to server. This operation will be tried later!', 16, 2 );
© www.soinside.com 2019 - 2024. All rights reserved.