sql - 如何在 SQL 中测试链接服务器的连接性

标签 sql tsql connection linked-server openquery

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

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

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

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

我真的很感激任何帮助。

最佳答案

您可以使用以下脚本

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 );

关于sql - 如何在 SQL 中测试链接服务器的连接性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10191193/

相关文章:

c# - 扩展数据上下文类(接口(interface)、新属性等)

mysql - MySQL 中何时使用单引号、双引号和反引号

sql-server - 有没有办法更改 FixedLenNullInSource 和 TrimTrailingBlanks 的值?

java - 如何通过 HttpPost 方法发送文本?

sql - Delphi加载图像保存为sql数据库中的blob

sql - 在 Scala Spark 的 for 循环中生成数据帧导致内存不足

SQL计算2列的百分比

sql - 比较 SQL 中的两个位掩码以查看是否有任何位匹配

java - 与本地 mysql 数据库连接时,getConnection 不是 JDBC 中的连接

java - 在 Netty (Java) 中,如何将接收到服务器的消息转发到另一个服务器?