南海网站设计,儿童手工制作,自建wordpress主题,邯郸信息港求职信息SQL Server 中关于 error 的一个小误区 原文:SQL Server 中关于 error 的一个小误区在SQL Server中#xff0c;我常常会看到有些前辈这样写#xff1a; if(error0)ROLLBACK TRANSACTION T
elseCOMMIT TRANSACTION T 一开始#xff0c;我看见别人这么写#xff0c;我… SQL Server 中关于 error 的一个小误区 原文:SQL Server 中关于 error 的一个小误区在SQL Server中我常常会看到有些前辈这样写 if(error0)ROLLBACK TRANSACTION T
elseCOMMIT TRANSACTION T 一开始我看见别人这么写我就想当然的以为它只是个计数器每当检测到一处错误时error的值1不过就因为这个理所当然所以杯具了... 实际上它并不是一个计数器它是一个动态的值动态的标识最后一条SQL命令执行的结果如果成功则为0不成功则标识错误码。所以像上面这种写法是不妥的举个例子如下 SET NOCOUNT ON;
SET XACT_ABORT ON; --执行 Transact-SQL 语句产生运行时错误则整个事务将终止并回滚BEGIN TRANSACTION TUPDATE Test
SET a已更新
WHERE a未更新RAISERROR (不好意思你没有权限,16,1)SELECT GETDATE()if(error0)ROLLBACK TRANSACTION T
elseCOMMIT 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 TRYBEGIN TRANSACTION TUPDATE TestSET a已更新WHERE a未更新RAISERROR (不好意思你没有权限,16,1)SELECT GETDATE()COMMIT TRANSACTION T
END TRY
BEGIN CATCHDECLARE msg nvarchar(2000)ERROR_MESSAGE() --将捕捉到的错误信息存在变量msg中 RAISERROR (msg,16,1) --此处才能抛出(好像是这样子....)ROLLBACK TRANSACTION T --出錯回滾事務
END CATCH posted on 2015-01-13 10:19 NET未来之路 阅读(...) 评论(...) 编辑 收藏 转载于:https://www.cnblogs.com/lonelyxmas/p/4220576.html