博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQL Server 中关于 @@error 的一个小误区
阅读量:6985 次
发布时间:2019-06-27

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

原文:

在SQL Server中,我常常会看到有些前辈这样写:

if(@@error<>0)    ROLLBACK TRANSACTION Telse    COMMIT TRANSACTION T

一开始,我看见别人这么写,我就想当然的以为它只是个计数器,每当检测到一处错误时,@@error的值+1,不过就因为这个理所当然,所以杯具了...

实际上,它并不是一个计数器,它是一个动态的值,动态的标识最后一条SQL命令执行的结果,如果成功则为0,不成功则标识错误码。所以,像上面这种写法是不妥的,举个例子,如下:

SET NOCOUNT ON;SET XACT_ABORT ON;  --执行 Transact-SQL 语句产生运行时错误,则整个事务将终止并回滚BEGIN TRANSACTION TUPDATE TestSET a='已更新'WHERE a='未更新'RAISERROR ('不好意思,你没有权限!',16,1) SELECT GETDATE()if(@@error<>0)    ROLLBACK TRANSACTION Telse    COMMIT TRANSACTION T

分析:

  按我以前的理解来说,【 RAISERROR ('不好意思,你没有权限!',16,1) 】这里抛出了一个错误,整个事务应该回滚才对,可是,它却没有回滚!!那么原因出在哪呢?原来,问题出在"SELECT GETDATE()"这句上面!因为执行RAISERROR语句时,@@error的值不为0(好像是5000),而当执行到下一句"SELECT GETDATE()"时,@@error的值又变为0了!所以,后面的if语句自然没有捕捉到任何错误...

 

对策:

  既然找到了原因,那解决办法自然也少不了。用Try...CATCH语法就可以了,语句如下:

SET NOCOUNT ON;SET XACT_ABORT ON;  --执行 Transact-SQL 语句产生运行时错误,则整个事务将终止并回滚BEGIN TRY    BEGIN TRANSACTION T    UPDATE Test    SET a='已更新'    WHERE a='未更新'    RAISERROR ('不好意思,你没有权限!',16,1)    SELECT GETDATE()        COMMIT TRANSACTION TEND TRYBEGIN CATCH    DECLARE @msg nvarchar(2000)=ERROR_MESSAGE()    --将捕捉到的错误信息存在变量@msg中                   RAISERROR (@msg,16,1)    --此处才能抛出(好像是这样子....)    ROLLBACK TRANSACTION T  --出錯回滾事務END CATCH

 

 

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

你可能感兴趣的文章
JAVA 8 函数式接口--Supplier
查看>>
Android HTTP
查看>>
Dockerfile多阶段构建原理和使用场景
查看>>
476-数字的补数
查看>>
SQLServer之删除索引
查看>>
七牛云赵之健:多维度融合赋能视频 AI 的实践
查看>>
Android 9 Pie震撼来袭 同步登陆WeTest
查看>>
vue+element Form键盘回车事件页面刷新解决
查看>>
CSS3中的box-sizing
查看>>
gracehttp: 优雅重启 Go 程序(热启动 - Zero Downtime)
查看>>
vue-cli中配置全局sass变量
查看>>
云计算新风向:多云战略优化企业云支出
查看>>
gweb总结之router
查看>>
【跃迁之路】【478天】刻意练习系列237(2018.05.29)
查看>>
Windows改Linux(一),新建Ubuntu虚拟机小白向导
查看>>
写了一个下拉刷新插件
查看>>
【Laravel】Laravel 框架关键技术解析·读书笔记(二)
查看>>
HTML5调用手机前置摄像头或后置摄像头拍照,canvas显示,经过Android测试
查看>>
如何做好 Android 端音视频测试?
查看>>
element 源码学习(番外篇) —— SASS五分钟快速入门
查看>>