首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SaveChanges无AcceptChanges

SaveChanges无AcceptChanges
EN

Stack Overflow用户
提问于 2017-01-16 10:22:01
回答 1查看 584关注 0票数 2

调用DbContext中的方法DbContext将使用默认的保存选项SaveOptions.AcceptAllChangesAfterSave调用ObjectContext中的SaveChanges

因此,所有更改都将在保存后进行记录。

我想在手动模式下控制它:

  1. 检测变化
  2. 保存更改
  3. 接受更改

现在,2和3是一次联合的,所以我不能在2到3之间做一些操作,我怎么能把它分开呢?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-01-16 13:03:14

根据Ivan Stoev的评论:

代码语言:javascript
复制
internal sealed class TestContext : DbContext
{
    protected ObjectContext ObjectContext => ((IObjectContextAdapter)this).ObjectContext;

    public override int SaveChanges()
    {
        //detect all changes in context
        ChangeTracker.DetectChanges();

        //write changes to database
        var result = ObjectContext.SaveChanges(System.Data.Entity.Core.Objects.SaveOptions.None);

        //do some actions with entities
        DoStuff();

        //accept all changes in entities
        ObjectContext.AcceptAllChanges();

        return result;
    }
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41674145

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档