为了账号安全,请及时绑定邮箱和手机立即绑定

SQL Serve中的Throw语句尝试

标签:
SQL Server

    SQL SERVER2012实现了类似C#抛出异常的Throw语句。相比较于SQL Server2005之前使用@@ERROR,和SQL Server2005之后使用RAISERROR()引发异常都是一个不小的进步,下面来看一下Throw的用法。

 

RAISERROR和THROW比较

    在SQL Server2005/2008中,使用RAISERROR和TRY…CATCH语句来抛出异常相比较根据@@ERROR进行判断来讲已经进步了很多。但是使用RAISERROR有一个非常不好的一点是无法返回真正出错的行数。如图1所示。

    https://img1.sycdn.imooc.com//5af2cd800001238a05250416.jpg

 

    而如果我们需要具体的错误信息,可能还需要这么写,如图2所示。

    https://img1.sycdn.imooc.com//5af2cd8b0001dfb509680368.jpg

 

    而使用SQL SERVER2012新增的THROW语句,则变得简单很多。并且能正确返回出错的行,对于比较长的T-SQL语句来说,这节省了不少时间,如图3所示。

    https://img1.sycdn.imooc.com//5af2cd980001680005570409.jpg

 

    我们也可以为THROW语句指定参数来返回自定义错误信息,但不能再标识出正确的错误行,如图4所示。

    https://img1.sycdn.imooc.com//5af2cda30001a34705350392.jpg

 

小结

    因此使用THROW语句可以带来如下好处

    1.更简洁优雅的代码

    2.可以正确的标识出出错的行数,对于大量T-SQL来说,这点可以节省不少时间

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消