博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQL Server2012中的Throw语句尝试
阅读量:6270 次
发布时间:2019-06-22

本文共 571 字,大约阅读时间需要 1 分钟。

简介

    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来说,这点可以节省不少时间

转载地址:http://ujlpa.baihongyu.com/

你可能感兴趣的文章
Aptana插件在eclipse中安装
查看>>
jQuery-数据管理-删除事件
查看>>
下载器简单实例
查看>>
java实现分页工具类(JDBC)
查看>>
欧几里德算法与扩展欧几里德算法
查看>>
Tinkoff Internship Warmup Round 2018 and Codeforces Round #475 (Div. 2)
查看>>
通过kafka提供的命令来查看offset消费情况
查看>>
oracle数据库从入门到精通之四
查看>>
自定义圆形图片控件
查看>>
sharepoint 2013 补丁升级步骤
查看>>
asp.net core 2.0 web api基于JWT自定义策略授权
查看>>
Skype for Business Server 2015-04-前端服务器-3-安装-管理工具
查看>>
第12章代码《跟老男孩学习Linux运维:Shell编程实战》
查看>>
我们为什么从Python转到go?
查看>>
5.Azure负载均衡(上)
查看>>
轻松精通awk数组企业问题案例
查看>>
26.Azure备份服务器(下)
查看>>
从“网上说的能信么”说开去---学习的思考
查看>>
DHCP 日志分析
查看>>
.NET Micro Framework动态调用C/C++底层代码(原理篇)
查看>>