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.使用RAISERROR返回错误行数不正确
而如果我们需要具体的错误信息,可能还需要这么写,如图2所示。
图2.错误信息写法比较麻烦
而使用SQL SERVER2012新增的THROW语句,则变得简单很多。并且能正确返回出错的行,对于比较长的T-SQL语句来说,这节省了不少时间,如图3所示。
图3.THROW正确返回出错行和出错信息
我们也可以为THROW语句指定参数来返回自定义错误信息,但不能再标识出正确的错误行,如图4所示。
图4.为THROW语句指定参数
小结
因此使用THROW语句可以带来如下好处
1.更简洁优雅的代码
2.可以正确的标识出出错的行数,对于大量T-SQL来说,这点可以节省不少时间
转自:https://www.cnblogs.com/CareySon/archive/2012/03/14/2395661.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
2019-05-18 windows系统磁盘IO性能测试(CrystalDiskMark硬盘检测工具)
2018-05-18 sql server学习路径地址
2018-05-18 如何在linux下安装jdk