转自https://www.cnblogs.com/delphinet/archive/2010/08/17/1801424.html

第一种:

 
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

最新文章

  1. goEasy消息推送,pushlet 向特写用户实时推送
  2. Android学习---数据库的增删改查(sqlite CRUD)
  3. ExpandableListView的用法
  4. 黑马程序员:Java编程_反射技术
  5. DOM节点操作
  6. 如何将phantomjs单独部署在服务端
  7. 一个考察for循环题 讨论一下
  8. [转]oracle的ANYDATA数据类型
  9. java 注解Annotation
  10. 自己在使用的English词典
  11. ASP.NET 防盗链的实现[HttpHandler]
  12. [原创]HTML5 web性能监控策略
  13. 又见angular----步一步做一个angular4小项目
  14. proc文件系统探索 之 根目录下的文件[三]
  15. [SpringBoot guides系列翻译]调用RESTfulWebService
  16. Vue 去掉#号,让网址像正常的一样
  17. CentOS下双网卡双IP不同IP段配置
  18. devexpress gridview 添加按钮
  19. Quart2D文字图像绘制
  20. linux上mysql安装详细教程

热门文章

  1. JavaScript高级程序设计学习笔记第十章--DOM
  2. VMware设置桥接网络
  3. 35.Docker安装Mysql挂载Host Volume
  4. Unity DOTS 走马观花
  5. Kbengine
  6. poj2449(k短路&A_star模板)
  7. 洛谷P3080 [USACO13MAR]牛跑The Cow Run
  8. 洛谷 P2216 [HAOI2007]理想的正方形
  9. Vue实现任务列表效果
  10. js的Element.scrollIntoView的学习