dreamontheway的技术之路

向着光明,我要一步一步往上爬。

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

SQL Server 事务及回滚事务

第一种:

复制代码
declare   @iErrorCount   int
set @iErrorCount = 0
begin tran Tran1
   
insert into t1(Id, c1) values(1,'1')
    
set @iErrorCount=@iErrorCount+@@error

   
insert into t1(Id, c1) values('XX2','2')
    
set @iErrorCount=@iErrorCount+@@error

if @iErrorCount=0
begin   
    
COMMIT TRAN Tran1  --执行事务
end
else   
begin   
    
ROLLBACK TRAN Tran1  --回滚事务
end
复制代码

第二种:

复制代码
Begin Try
    
Begin Tran Tran1
        
insert into t1(Id, c1) values(1,'1')
        
insert into t1(Id, c1) values('XX2','2')  --此句产生错误
    COMMIT TRAN Tran1
END Try
Begin Catch
    
raiserror 50005N'出错了'
    
ROLLBACK TRAN Tran1     ---出错后调用回滚
END Catch
复制代码

第三种:

SET XACT_ABORT ON ----语句产生运行时错误,则整个事务将终止并回滚。
Begin Tran
    
INSERT INTO t1(Id, c1) VALUES(1,'1')
    
INSERT INTO t1(Id, c1) VALUES('XX2','2') --此句产生错误时,就会回滚整个事务
Commit Tran

阅读全文
类别:sql ado 存储过程 查看评论

posted on   dreamontheway  阅读(199)  评论(0编辑  收藏  举报

编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 25岁的心里话
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示