作业真的成功了吗?_链接服务器远程存储过程调用失败
2017-03-11 09:43
246 查看
工作环境中,之前遇到了一个问题. 作业中使用链接服务器远程存储过程调用. 实际是失败了,但代理作业并没有报出这个错误.查了一下在2008年,就有这个报告了.https://connect.microsoft.com/SQLServer/feedback/details/337043/no-error-raised-when-a-remote-procedure-times-out 例子:1.建立一个链接服务器
EXEC master.dbo.sp_addlinkedserver @server = N'LOCALHOST', @srvproduct=N'SQL Server' EXEC master.dbo.sp_addlinkedsrvlogin @rmtsrvname=N'LOCALHOST',@useself=N'True',@locallogin=NULL,@rmtuser=NULL,@rmtpassword=NULL EXEC master.dbo.sp_serveroption @server=N'LOCALHOST', @optname=N'rpc', @optvalue=N'true' EXEC master.dbo.sp_serveroption @server=N'LOCALHOST', @optname=N'rpc out', @optvalue=N'true'
2.将timeout修改为5秒
exec sp_configure'remote query timeout', 5 reconfigure
3.执行模拟查询超时
DECLARE @returnCode int = 0 DECLARE @sql nvarchar(max) = 'WAITFOR DELAY ''00:00:06''; exec sp_who2' EXEC @returnCode = [localhost].master.dbo.sp_executesql @sql
注意:消息对话框显示一条警告消息来说明查询超时。但未返回任何结果,并且也没有引发错误。
就是这么个错误.在实际使用中一定要小心.
下面是做了一个补救措施.就是把错误报出来.抓错误,就是用try…catch啦.
BEGIN TRY DECLARE @returnCode int = 0 DECLARE @linkedServer sysname = 'localhost' DECLARE @databaseName sysname = 'master' DECLARE @procErrorMsg nvarchar(255) = N'远程存储过程 %s 在数据库 %s 使用链接服务器 %s 失败.' DECLARE @procName sysname DECLARE @sql nvarchar(max) SET @procName = 'sp_who' SET @sql = 'WAITFOR DELAY ''00:00:06''; exec ' + @procName EXEC @returnCode = [localhost].master.dbo.sp_executesql @sql IF @returnCode IS NULL BEGIN RAISERROR (@procErrorMsg, 16, 1, @procName, @databaseName, @linkedServer) END SET @procName = 'sp_who2' SET @sql = 'WAITFOR DELAY ''00:00:06''; exec ' + @procName EXEC @returnCode = [localhost].master.dbo.sp_executesql @sql IF @returnCode IS NULL BEGIN RAISERROR (@procErrorMsg, 16, 1, @procName, @databaseName, @linkedServer) END END TRY BEGIN CATCH DECLARE @errorMessage nvarchar(max) DECLARE @errorSeverity tinyint DECLARE @errorState tinyint SELECT @errorMessage = ERROR_MESSAGE(), @errorSeverity = ERROR_SEVERITY(), @errorState = ERROR_STATE() RAISERROR (@errorMessage, @errorSeverity, @errorState) END CATCH
测试了一下,在最新的版本里面2016 SP1 13.0.4001中这个问题还是存在.
相关文章推荐
- [转]SQLSERVER存储过程调用不同数据库的数据_存储过程中通过链接服务器访问远程服务器
- 调用存储过程显示登录失败,可能是链接服务器错误
- sqlserver 链接服务器在存储过程中调用的设置
- SQLServer作业调用链接服务器失败解决办法
- 运用ORACLE的OO4O类库函数解决调用存储过程向远程数据库上传超过32K图片失败的问题
- 如何执行远程链接服务器的存储过程,并插入到本地表
- SQLServer作业调用链接服务器失败解决办法
- 作业中调用存储过程不成功
- 利用Sql作业在asp.net 里面实现异步调用存储过程.
- SQL Server创建链接服务器的一些存储过程和例子
- 创建链接服务器远程登录映射报错:消息15466 解密过程中出错解决办法
- 使用链接服务器执行远程数据库上的存储过程_SQL技巧
- SQL SERVER 数据库通过连接服务器 调用ORACLE 数据库中的存储过程
- Sql server 跨服务器在一个存储过程sp_A中调用另一个存储过程sp_B
- SQL存储过程调用作业的方法
- 创建链接服务器、调用远程存储过程
- SSIS调用存储过程失败
- vc6.0链接数据库调用存储过程
- 在SQL SERVER中执行链接服务器上的带有参数的存储过程