最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

SQLServer异常捕获,回滚,再抛出

来源:动视网 责编:小采 时间:2020-11-09 15:34:11
文档

SQLServer异常捕获,回滚,再抛出

SQLServer异常捕获,回滚,再抛出:一个存储过程中多个更新操作, 后面的更新操作出现异常,如果 不手动回滚 前面修改的数据是不会自动撤销的! BEGIN TRY BEGIN TRAN -- ..... COMMIT TRAN END TRY BEGIN CATCH ROLLBACK TRAN DECLARE @ErrorMessag NVARC
推荐度:
导读SQLServer异常捕获,回滚,再抛出:一个存储过程中多个更新操作, 后面的更新操作出现异常,如果 不手动回滚 前面修改的数据是不会自动撤销的! BEGIN TRY BEGIN TRAN -- ..... COMMIT TRAN END TRY BEGIN CATCH ROLLBACK TRAN DECLARE @ErrorMessag NVARC


一个存储过程中多个更新操作, 后面的更新操作出现异常,如果 不手动回滚 前面修改的数据是不会自动撤销的! BEGIN TRY BEGIN TRAN -- ..... COMMIT TRAN END TRY BEGIN CATCH ROLLBACK TRAN DECLARE @ErrorMessag NVARCHAR ( 255 ) SELECT @ErrorMessag = E

一个存储过程中多个更新操作,后面的更新操作出现异常,如果不手动回滚前面修改的数据是不会自动撤销的!

BEGIN TRY
 BEGIN TRAN
-- .....
 COMMIT TRAN
END TRY

BEGIN CATCH
 ROLLBACK TRAN

 DECLARE @ErrorMessag NVARCHAR(255)
 SELECT @ErrorMessag = Error_message()
 RAISERROR (15600,-1,-1,@ErrorMessag);
END CATCH

另参考: http://msdn.microsoft.com/zh-cn/library/ms178592.aspx

BEGIN TRY
 -- RAISERROR with severity 11-19 will cause execution to 
 -- jump to the CATCH block.
 RAISERROR ('Error raised in TRY block.', -- Message text.
 16, -- Severity.
 1 -- State.
 );
END TRY
BEGIN CATCH
 DECLARE @ErrorMessage NVARCHAR(4000);
 DECLARE @ErrorSeverity INT;
 DECLARE @ErrorState INT;

 SELECT 
 @ErrorMessage = ERROR_MESSAGE(),
 @ErrorSeverity = ERROR_SEVERITY(),
 @ErrorState = ERROR_STATE();

 -- Use RAISERROR inside the CATCH block to return error
 -- information about the original error that caused
 -- execution to jump to the CATCH block.
 RAISERROR (@ErrorMessage, -- Message text.
 @ErrorSeverity, -- Severity.
 @ErrorState -- State.
 );
END CATCH;

文档

SQLServer异常捕获,回滚,再抛出

SQLServer异常捕获,回滚,再抛出:一个存储过程中多个更新操作, 后面的更新操作出现异常,如果 不手动回滚 前面修改的数据是不会自动撤销的! BEGIN TRY BEGIN TRAN -- ..... COMMIT TRAN END TRY BEGIN CATCH ROLLBACK TRAN DECLARE @ErrorMessag NVARC
推荐度:
标签: 一个 过程 错误
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top