SQL Server 中关于 @@error 的一个小误区
2017-05-31 11:13
141 查看
在SQL Server中,我常常会看到有些前辈这样写:
一开始,我看见别人这么写,我就想当然的以为它只是个计数器,每当检测到一处错误时,@@error的值+1,不过就因为这个理所当然,所以杯具了…
实际上,它并不是一个计数器,它是一个动态的值,动态的标识最后一条SQL命令执行的结果,如果成功则为0,不成功则标识错误码。所以,像上面这种写法是不妥的,举个例子,如下:
分析:
按我以前的理解来说,【 RAISERROR (‘不好意思,你没有权限!’,16,1) 】这里抛出了一个错误,整个事务应该回滚才对,可是,它却没有回滚!!那么原因出在哪呢?原来,问题出在”SELECT GETDATE()”这句上面!因为执行RAISERROR语句时,@@error的值不为0(好像是5000),而当执行到下一句”SELECT GETDATE()”时,@@error的值又变为0了!所以,后面的if语句自然没有捕捉到任何错误…
对策:
既然找到了原因,那解决办法自然也少不了。用Try…CATCH语法就可以了,语句如下:
if(@@error<>0) ROLLBACK TRANSACTION T else COMMIT TRANSACTION T
一开始,我看见别人这么写,我就想当然的以为它只是个计数器,每当检测到一处错误时,@@error的值+1,不过就因为这个理所当然,所以杯具了…
实际上,它并不是一个计数器,它是一个动态的值,动态的标识最后一条SQL命令执行的结果,如果成功则为0,不成功则标识错误码。所以,像上面这种写法是不妥的,举个例子,如下:
SET NOCOUNT ON;
SET XACT_ABORT ON; --执行 Transact-SQL 语句产生运行时错误,则整个事务将终止并回滚
BEGIN TRANSACTION T
UPDATE Test
SET a='已更新'
WHERE a='未更新'
RAISERROR ('不好意思,你没有权限!',16,1)
SELECT GETDATE()
if(@@error<>0) ROLLBACK TRANSACTION T else 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 T END TRY BEGIN CATCH DECLARE @msg nvarchar(2000)=ERROR_MESSAGE() --将捕捉到的错误信息存在变量@msg中 RAISERROR (@msg,16,1) --此处才能抛出(好像是这样子....) ROLLBACK TRANSACTION T --出錯回滾事務 END CATCH
相关文章推荐
- SQL Server 中关于 @@error 的一个小误区
- SQL Server 中关于 @@error 的一个小误区
- Sql Server 中关于@@ERROR的一个小小误区
- SQL Server 中关于 @@error 的一个小误区
- sql server 2000下的关于“provider: TCP 提供程序, error: 0 - 远程主机强迫关闭了一个现有的连接”问题的解决
- 简述一个关于null的理解误区:null不等于null
- 关于政府房价调控的一个误区
- 关于sql server 存储图片的一个简单方法
- 关于SQL Server 2000遍历记录集时出现错误:Unkown error:0x800A0CB3的处理
- 关于SQL server 2008不能启动的一个解决办法
- 一个误区(关于javascript的字符串拼接)
- 关于 HTTP GET/POST 请求参数长度最大值的一个理解误区(转载)
- 一个误区(关于javascript的字符串拼接)
- WinSocket套接字关于Connect函数通过GetLastError 返回10038或者(在一个非套接字上尝试了一个操作)
- 关于virtualbox不能为虚拟电脑启动一个新任务报错 GetLastError=1790(其他错误id也可以一试)的问题
- 关于静态成员变量在类继承中的一个误区
- 论坛中一个关于SQL Server调度,作业等的答问。
- (转载和原创)关于解决C++“error LNK1169: 找到一个或多个多重定义的符号”的解决方法
- logback框架使用误区 如何将所有包的ERROR级别日志集中打印到一个日志文件中
- 关于LVS-DR中的一个普遍误区:lo:0配置路由