我需要编写一个程序来从多个远程服务器收集数据,
我使用链接服务器和OPENQUERY从服务器收集数据,但有时我会丢失与某些服务器的连接,或者我根本无法连接它们(例如远程服务器处于脱机状态) - 并且在这些情况下OPENQUERY会导致超时
所以我想首先检查链接服务器连接,然后如果它成功运行查询,如果不是只是转到下一个远程服务器。
我试图将OPENQUERY置于TRY - CATCH但它仍然返回超时错误,sp_testlinkedserver程序也让我超时错误。
我真的很感激任何帮助。
答案 0 :(得分:15)
您可以使用以下脚本
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 );
答案 1 :(得分:0)
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') ;