SQL begin catch throw

http://www.cnblogs.com/CareySon/archive/2012/03/14/2395661.html

SQL Server2012中的Throw语句尝试

 

简介

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

 

RAISERROR和THROW比较

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

    1

    图1.使用RAISERROR返回错误行数不正确

 

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

    2

    图2.错误信息写法比较麻烦

 

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

    3

    图3.THROW正确返回出错行和出错信息

 

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

    4

    图4.为THROW语句指定参数

 

   

小结

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

    1.更简洁优雅的代码

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

posted @   阿玛  阅读(283)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 字符编码:从基础到乱码解决
点击右上角即可分享
微信分享提示