SQL Server2012中的Throw语句尝试

来源:未知 责任编辑:责任编辑 发表时间:2014-05-10 12:27 点击:
简介
    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来说,这点可以节省不少时间



作者 宋沄剑
    发表评论
    请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
    用户名: 验证码:点击我更换图片
    最新评论 更多>>

    推荐热点

    • sql常见面试题
    • SQL SERVER 2005性能之跟踪
    • SQL编程(一)
    • LINUX上RMAN自动备份脚本
    • sql server面试题
    • 如何将多个SQL查询统计结果一次显示出来
    • 浅谈SQL Server中的事务日志(三)----在简单恢复模式下日志的角色
    • sql server 列转行
    • SQL小技巧系列 --- 行转列合并
    网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
    Copyright © 2008-2015 计算机技术学习交流网. 版权所有

    豫ICP备11007008号-1