编程的异常处理很重要,当然Sql语句中存储过程的异常处理也很重要,明确的异常提示能够快速的找到问题的根源,节省很多时间。
为乌什等地区用户提供了全套网页设计制作服务,及乌什网站建设行业解决方案。主营业务为网站制作、成都做网站、乌什网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!
下面,我就以一个插入数据为例来说明Sql Server中的存储过程怎么捕获异常的 。
就以插入数据为例,其他的可以照着写就行了。
编程语言都有异常的捕获与处理, 在 SqlServer2008 中也是这样子的。
对会出现异常的语句加上 begin try……end try ,然后进行异常捕捉:begin catch……end catch即可。
错误代码详解 很容易就能找到。
代码如下:
- Create proc sp_Insert_Course
- @No char(10),
- @Name varchar(20),
- @Comment varchar(50),
- @rtn int output
- as
- begin try
- insert into Course values(@No,@Name,@Comment)
- set @rtn=1
- end try
- begin catch
- set @rtn=@@ERROR
- --辅助信息
- --select ERROR_LINE() as Line,
- -- ERROR_MESSAGE() as message1,
- -- ERROR_NUMBER() as number,
- -- ERROR_PROCEDURE() as proc1,
- -- ERROR_SEVERITY() as severity,
- -- ERROR_STATE() as state1
- end catch
相关代码如下:
- declare
- @rtn int
- exec sp_Insert_Course '114','语文','',@rtn output
- print @rtn
执行结果:
正常的情况下,返回值为1,
如果已经存在编号为“114”的数据,就会返回 ERROR_CODE:2627,
其他的异常情况会返回相应的代码
如果程序有异常,把异常代码返回,然后再进行相关的处理即可。
SQL Server中的异常处理和别的数据库(如Oracle)的有点差异,但是基本思想差不多, 在最后捕获都可以得到异常。
希望能够对大家有所帮助。
原文链接:http://www.cnblogs.com/sshoub/archive/2011/08/12/2136267.html
网站标题:说说SQLServer存储过程中的异常处理
URL分享:http://www.mswzjz.com/qtweb/news30/168680.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联