5

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

我使用linkedservers 和OPENQUERY 从服务器收集数据,但有时我会失去与某些服务器的连接,或者我根本无法连接它们(例如远程服务器离线)——在这些情况下,OPENQUERY 会导致超时。

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

我试图将 OPENQUERY 放在 TRY - CATCH 中,但它仍然返回超时错误,sp_testlinkedserver 过程也返回超时错误。

我真的很感激任何帮助。

4

2 回答 2

17

您可以使用以下脚本

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 );
于 2012-04-17T12:26:44.637 回答
2
USE master;  
GO  
sp_testlinkedserver [LINKED_SERVER_NAME];  
GO 

或者

SELECT * FROM OPENQUERY(LINKED_SERVER_NAME , 'select name DATABASE_NAME ,SYS_CONTEXT (''USERENV'', ''SESSION_USER'') USERNAME, host_name from v$database, dual, v$instance') ;
于 2020-06-11T10:27:18.473 回答