设为首页 收藏本站
查看: 883|回复: 0

[经验分享] SQL Server的过程异常扑捉

[复制链接]

尚未签到

发表于 2016-11-1 00:27:39 | 显示全部楼层 |阅读模式
http://www.cnblogs.com/sshoub/archive/2011/08/12/2136267.html
编程的异常处理很重要,当然Sql语句中存储过程的异常处理也很重要,明确的异常提示能够快速的找到问题的根源,节省很多时间。
下面,我就以一个插入数据为例来说明Sql Server中的存储过程怎么捕获异常的 。
1、环境
  (1)数据库为Sql Server2008。
  (2)表(Course)结构为:
    No char(10)  primary key
    Name varchar(20)
    Comment varchar(50)
2、存储过程
  就以插入数据为例,其他的可以照着写就行了。  
  编程语言都有异常的捕获与处理, 在 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

3、存储过程执行
  相关代码如下:
declare
@rtn int
exec sp_Insert_Course '114','语文','',@rtn output
print @rtn

 执行结果:
  正常的情况下,返回值为1,
  如果已经存在编号为“114”的数据,就会返回 ERROR_CODE:2627,
  其他的异常情况会返回相应的代码
4、说明
  如果程序有异常,把异常代码返回,然后再进行相关的处理即可。
   SQL Server中的异常处理和别的数据库(如Oracle)的有点差异,但是基本思想差不多, 在最后捕获都可以得到异常。
  希望能够对大家有所帮助。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-293790-1-1.html 上篇帖子: SQL SERVER SQL Agent服务使用技巧小结 下篇帖子: 理解SQL Server中页和盘区
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表