---开启事务
BEGIN TRAN --错误捕捉机制,看好啦,这里也有的。并且可以嵌套。
BEGIN TRY --语句正确
insert into lives (Eat,Play,Numb) values ('猪肉','足球',1) --Numb为int类型,出错
insert into lives (Eat,Play,Numb) values ('猪肉','足球','abc') ;
END TRY
BEGIN CATCH
select Error_number() as ErrorNumber, --错误代码
Error_severity() as ErrorSeverity, --错误严重级别,级别小于10 try catch 捕获不到
Error_state() as ErrorState , --错误状态码
Error_Procedure() as ErrorProcedure , --出现错误的存储过程或触发器的名称。
Error_line() as ErrorLine, --发生错误的行号
Error_message() as ErrorMessage --错误的具体信息
IF(@@TRANCOUNT >0) --全局变量@@trancount,事务开启此值+1,他用来判断是有开启事务
SET @ERR_MSG=error_message()
ROLLBACK TRAN ---由于出错,这里回滚到开始,插入失效
END CATCH
IF (@@TRANCOUNT >0)
COMMIT TRAN --如果成功Lives表中,将会有3条数据。
KSO - sqlserver事务实现
最新推荐文章于 2024-09-30 20:09:33 发布