C#提高知识 ADO.NET实体数据模型(3)-关于回滚

ADO.NET 实体数据模型,其实我是不太喜欢用这个,主要是遇到复杂查询时linq语句写起来比较多,当然也是可以直接执行sql语句的,但是执行复杂sql时还是执行不了,因为连接有问题。
但是ADO.NET实体有个优点就是,能实时更新数据库的变化,并且自动更新模型,基于这一点也是我在使用纯sql语句的时候,还是坚持使用了不少实体数据模型的。
这几天打算用实体模型写一个多表顺序修改的的数据库操作的功能,也就是上一个表或记录修改成功才能进行下一个表或记录的修改。这里就涉及到回滚的问题了。
我原本以为提供的有回滚的机制,不过没找到,不知道是不是我的资料不全。
我觉得可以用如下方法解决。
1、如果是同一个Entities下,最好将每个表的记录依次修改,然后最后只运行一个SaveChanges(),来达到同时提交的目的。
例,表名为虚构,
            using (MyEntities aentity = new MyEntities())
            {
                TAB_MEMBER tab1 = aentity.TAB_MEMBER.Where(o => o.ID == "123").FirstOrDefault();


                tab1.TBM_ID = "234";


                TAB_EMPLOYEE tab2 = aentity.TAB_EMPLOYEE.Where(o => o.ID == "id1").FirstOrDefault();


                tab2.TBA_ID = "id2";


                aentity.SaveChanges();
            }

2、可以将旧的记录在一个新的实例中保存起来。但是不是引用赋值,而是将旧的记录的字段和属性,一次赋值给新的实例。然后保存修改,如果出错后,将新的实例的值再赋值给当前要修改的记录,再次保存。
也就是如下关系:
记录1副本=记录1;
bool r= 保存记录1;

if(r)
{
  bool r2 = 保存记录2;
  if(!r2)
  {
   将记录一的副本重新保存,覆盖掉记录1的修改。
  }
}
目前来说,我会使用这两种方式解决回滚问题。欢迎大家交流。
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值