SQL Server 2012 Throw关键字

这个是完全copy 宋大侠的文章,他的文章都是经典,绝对是学习的佳品。

简介:

SQL SERVER2012实现了类似C#抛出异常的Throw语句。相比较于SQL Server2005之前使用@@ERROR,和SQL Server2005之后使用RAISERROR()引发异常都是一个不小的进步,下面来看一下Throw的用法。
 
RAISERROR和THROW比较:
    在SQL Server2005/2008中,使用RAISERROR和TRY…CATCH语句来抛出异常相比较根据@@ERROR进行判断来讲已经进步了很多。但是使用RAISERROR有一个非常不好的一点是无法返回真正出错的行数。

如图1所示。

图1.使用RAISERROR返回错误行数不正确
 
    而如果我们需要具体的错误信息,可能还需要这么写,如图2所示。

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

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

 图4.为THROW语句指定参数
 
  
小结
    因此使用THROW语句可以带来如下好处
    1.更简洁优雅的代码
    2.可以正确的标识出出错的行数,对于大量T-SQL来说,这点可以节省不少时间

 

转载于:https://www.cnblogs.com/ziqiumeng/p/10328048.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值