博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PetaPoco4.0的事务为什么不会回滚
阅读量:7026 次
发布时间:2019-06-28

本文共 1436 字,大约阅读时间需要 4 分钟。

using (var srop=DbHelper.CurrentDb.GetTransaction())        {            ID = bp.AddModel(model).ToStr();            #region 参与楼盘信息            if (ID.ToInt32() > 0) { FY_ActivityProjectServer dtlServer = new FY_ActivityProjectServer(); for (int i = 0; i <= this.Projects.Items.Count; i++) { if (this.Projects.Items[i].Selected) { FY_ActivityProject dtl = new FY_ActivityProject(); dtl.ActivityID = ID.ToInt32(); dtl.ProjectID = this.Projects.Items[i].Value.ToInt32(); dtl.IsDel = false; dtlList.Add(dtl); } } dtlServer.AddModel(dtlList); } #endregion srop.Complete(); }

以上是第一种写法

下面是第二种写法:

DbHelper.CurrentDb.BeginTransaction();//事务开始        this.ModelDataCollect();        FY_ActivityServer bp = new FY_ActivityServer(); try { ID = bp.AddModel(model).ToStr(); #region 参与楼盘信息 if (ID.ToInt32() > 0) { FY_ActivityProjectServer dtlServer = new FY_ActivityProjectServer(); for (int i = 0; i <= this.Projects.Items.Count; i++) { if (this.Projects.Items[i].Selected) { FY_ActivityProject dtl = new FY_ActivityProject(); dtl.ActivityID = ID.ToInt32(); dtl.ProjectID = this.Projects.Items[i].Value.ToInt32(); dtl.IsDel = false; dtlList.Add(dtl); } } dtlServer.AddModel(dtlList); } #endregion DbHelper.CurrentDb.CompleteTransaction(); } catch (Exception) { DbHelper.CurrentDb.AbortTransaction(); }

以上操作有两个insert操作

第一个insert能插入成功,第二个insert方法故意让它报错,

问题来了,

PetaPoco 不会回滚,导致第一个操作插入成功,第二个操作插入失败

求解决方案

转载于:https://www.cnblogs.com/ezplusy/p/4074008.html

你可能感兴趣的文章
Codeforces Round #309 (Div. 2) B. Ohana Cleans Up
查看>>
用简单的C语言实现多任务轮流切换(模拟操作系统线程机制)
查看>>
android Recyclerview仿京东,滚动屏幕标题栏渐变(启动页面动画)
查看>>
C语言之数值计算--级数算法
查看>>
C++之引用
查看>>
MFC学习笔记之三(粒子系统+怪物简单AI+碰撞检测)
查看>>
ios xmpp研究探索:发送文本消息
查看>>
费用流模板
查看>>
Makefile规则详解
查看>>
明星讲师心石闪耀ArchSummit大会 | 手机淘宝构架演化实践
查看>>
数据展示方式之树形展示+H5拖动效果
查看>>
汇编语言学习与记录(3)
查看>>
设计模式: Java中的工厂设计模式
查看>>
无缝轮播的实现思路
查看>>
小程序的学习
查看>>
framework插件化技术-类加载
查看>>
Spring工作原理及流程
查看>>
解决1px的border在移动端变粗的问题
查看>>
InterviewMap —— Javascript (二)
查看>>
js数组操作
查看>>