MSSql异常处理框架

模拟实现异常堆栈,报告调用链和异常位置,代码如下:

CREATE PROC [MyHelper].[ThrowError]
    @ProcId INT
AS
--对于重新封装Error,微软有个raiserror方案:[sys].[sp_replrethrow]

IF ERROR_NUMBER() IS NULL RETURN;
DECLARE @_ProcName SYSNAME=ISNULL(LTRIM(RTRIM(OBJECT_NAME(@ProcId))),‘出错位置不详‘)
	,@_Num INT=ERROR_NUMBER()
	,@_Msg NVARCHAR(4000)=ERROR_MESSAGE()
	,@_Line NVARCHAR(100)=ISNULL(CONVERT(NVARCHAR,ERROR_LINE()),‘未知‘)
	,@_State TINYINT=ERROR_STATE()
	,@_NumCaption NVARCHAR(50)
	,@_MsgCaption NVARCHAR(50)
	,@_Severity INT=ERROR_SEVERITY()
	;
IF @_Num<50000 BEGIN
	SET @_NumCaption=‘ ,ErrorNum:‘+CONVERT(NVARCHAR,@_Num);
	SET @[email protected]_Num;
	SET @_MsgCaption=‘,Message:‘;
	END
ELSE BEGIN
	SET @_NumCaption=‘‘;
	SET @[email protected]_State+1;
	SET @_MsgCaption=‘;‘+CHAR(13)+char(10);
	END

SET @_Msg=‘第‘+CONVERT(NVARCHAR,@_State)+‘层:‘
	+‘Procedure:‘[email protected]_ProcName+‘,Line:‘[email protected]_Line
	[email protected]_NumCaption
	+ @_MsgCaption
	[email protected]_Msg;

THROW @_Num,@_Msg,@_State;

使用方法:

BEGIN TRY
	EXEC SP_EXECUTESQL N‘SELECT 1 FROM tbl;‘;

END TRY
BEGIN CATCH
EXEC MyHelper.ThrowError @@PROCID;
END CATCH
SET NOCOUNT OFF;
时间: 2024-10-06 09:37:20

MSSql异常处理框架的相关文章

异常以及异常处理框架探析

概述 一般情况下,企业级应用都对应着复杂的业务逻辑,为了保证系统的健壮,必然需要面对各种系统业务异常和运行时异常. 不好的异常处理方式容易造成应用程序逻辑混乱,脆弱而难于管理.应用程序中充斥着零散的异常处理代码,使程序代码晦涩难懂.可读性差,并且难于维护. 一个好的异常处理框架能为应用程序的异常处理提供统一的处理视图,把异常处理从程序正常运行逻辑分离出来,以至于提供更加结构化以及可读性的程序架构.另外,一个好的异常处理框架具备可扩展性,很容易根据具体的异常处理需求,扩展出特定的异常处理逻辑. 另

异常处理框架一:需求与基本结构说明

基本需求: 能对异常进行统一处理,处理方式可配置(xml) 基本的处理方式分为忽略.记录日志.提示用户(web或客户端).重新抛出(对重新抛出的异常不再处理)等 用户可扩展添加自己的处理方式 框架基本结构说明: Handler:用户调用的接口,调用时必须传递异常信息,可选参数可以传递输出方式.提示信息 public static void Handle(Exception ex) public static void Handle(Exception ex, string errorString

java异常处理和设计

在程序设计中,进行异常处理是非常关键和重要的一部分.一个程序的异常处理框架的好坏直接影响到整个项目的代码质量以及后期维护成本和难度.试想一下,如果一个项目从头到尾没有考虑过异常处理,当程序出错从哪里寻找出错的根源?但是如果一个项目异常处理设计地过多,又会严重影响到代码质量以及程序的性能.因此,如何高效简洁地设计异常处理是一门艺术,本文下面先讲述Java异常机制最基础的知识,然后给出在进行Java异常处理设计时的几个建议. 若有不正之处,请多多谅解和指正,不胜感激. 请尊重作者劳动成果,转载请标明

Java中异常处理和设计(转)

在程序设计中,进行异常处理是非常关键和重要的一部分.一个程序的异常处理框架的好坏直接影响到整个项目的代码质量以及后期维护成本和难度.试想一下,如果一个项目从头到尾没有考虑过异常处理,当程序出错从哪里寻找出错的根源?但是如果一个项目异常处理设计地过多,又会严重影响到代码质量以及程序的性能.因此,如何高效简洁地设计异常处理是一门艺术,本文下面先讲述Java异常机制最基础的知识,然后给出在进行Java异常处理设计时的几个建议. 若有不正之处,请多多谅解和指正,不胜感激. 请尊重作者劳动成果,转载请标明

[查异常网]-20160331-谈谈J2EE项目中的异常处理

为什么要在J2EE项目中谈异常处理呢?可能许多java初学者都想说:“异常处理不就是try….catch…finally吗?这谁都会啊!”.笔者在初学java时也是这样认为的.如何在一个多层的j2ee项目中定义相应的异常类?在项目中的每一层如何进行异常处理?异常何时被抛出?异常何时被记录?异常该怎么记录?何时需要把checked Exception转化成unchecked Exception ,何时需要把unChecked Exception转化成checked Exception?异常是否应该

Java异常处理和设计【转】

Java异常处理和设计 在程序设计中,进行异常处理是非常关键和重要的一部分.一个程序的异常处理框架的好坏直接影响到整个项目的代码质量以及后期维护成本和难度.试想一下,如果一个项目从头到尾没有考虑过异常处理,当程序出错从哪里寻找出错的根源?但是如果一个项目异常处理设计地过多,又会严重影响到代码质量以及程序的性能.因此,如何高效简洁地设计异常处理是一门艺术,本文下面先讲述Java异常机制最基础的知识,然后给出在进行Java异常处理设计时的几个建议. 若有不正之处,请多多谅解和指正,不胜感激. 请尊重

J2EE项目异常处理(转)

为什么要在J2EE项目中谈异常处理呢?可能许多java初学者都想说:“异常处理不就是try….catch…finally吗?这谁都会啊!”.笔者在初学java时也是这样认为的.如何在一个多层的j2ee项目中定义相应的异常类?在项目中的每一层如何进行异常处理?异常何时被抛出?异常何时被记录?异常该怎么记录?何时需要把checked Exception转化成unchecked Exception ,何时需要把unChecked Exception转化成checked Exception?异常是否应该

《开源框架那些事儿26》:“最好的模板引擎”Beetl剖析及与Tiny模板引擎对比

查找最好的模板引擎,发现这个搜索词出来的是beetl,于是就仔细学习了Beetl,试图找寻“最好的”三个字表现在哪里?于是搭建环境,阅读代码,与鄙人所做的TinyTemplate进行了粗略的对比,在征得beetl作者@闲.大赋 的同意后,编写了此对比文章.由于时间关系,对Beetl的认知深度还有不足,分析不当之处在所难免,还请广大同学纠正,定当有错误和不当必改. 点滴悟透设计思想,加入框架设计兴趣小组:http://bbs.tinygroup.org/group-113-1.html Beetl

C#异常处理经验(原则与方法)

本文是异常处理经验性的文章,其实跟C#关系也不大.比较适合刚刚熟悉异常语法,而缺乏实战的读者.当然,经验老练的读者也可指出不足.给予意见.补充说明,一起完善文章,分享更多知识与经验.   1.什么时候该异常处理? 1)代码最外层,如WinFrom,避免用户看到内部异常信息用户体验不好,或者造成程序崩溃,可以用log4net之类的框架记录异常. 2)遇到异常需要恢复状态或者重试的地方.例如连接数据库偶然失败了,可以有个重连机制,在Catch块重新连接数据库. 3)对于一系列有可能失败的任务,其中有