5

複数のリモート サーバーからデータを収集する手順を記述する必要があります。

リンクサーバーと OPENQUERY を使用してサーバーからデータを収集しますが、一部のサーバーへの接続が失われたり、単純に接続できない場合があります (たとえば、リモートサーバーがオフラインです)。このような場合、OPENQUERY はタイムアウトになります。

したがって、最初にリンクサーバーの接続を確認し、成功した場合はクエリを実行し、次のリモートサーバーに移動するだけではありませんでした。

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 に答える