EF 4 似乎无法调用 SaveChanges

发布于 2024-10-29 02:28:13 字数 645 浏览 7 评论 0原文

我有这个上下文与以下方法覆盖:

  public class MyContext : DbContext
  { 
    public DbSet<Contract> Contracts{get;set;}  
    public override int SaveChanges()
    {
        Contract ctr = new Contract
        {
            ContractId = "CT99999991",
            ContractNumber = "9000",
            LastModifiedDate = DateTime.Now,
            GracePeriod = DateTime.Now,
            ShipByDate = DateTime.Now,
            ExpirationDate = DateTime.Now
        };
        this.Contracts.Add(ctr);
        return base.SaveChanges();
    }
  }

无论我尝试什么,我都没有成功地使这部分代码成功。 我希望在 SaveChanges 事件发生时将上层合同保存在数据库中。 有什么我忽略的吗?

I have this Context with the following method override :

  public class MyContext : DbContext
  { 
    public DbSet<Contract> Contracts{get;set;}  
    public override int SaveChanges()
    {
        Contract ctr = new Contract
        {
            ContractId = "CT99999991",
            ContractNumber = "9000",
            LastModifiedDate = DateTime.Now,
            GracePeriod = DateTime.Now,
            ShipByDate = DateTime.Now,
            ExpirationDate = DateTime.Now
        };
        this.Contracts.Add(ctr);
        return base.SaveChanges();
    }
  }

No matter what I tried, I never succeed in making this part of the code succeed.
I would love to save the upper Contract in the database on SaveChanges event occurence.
Is there something I'm overlooking ?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

时光病人 2024-11-05 02:28:13

这不是我自己尝试做的事情,但有可能因为您已经在 SaveChanges() 方法中,所以上下文的更改列表已经创建。因此,当您将新的 Contract 添加到上下文的 Contracts 集合中时,您必须让上下文重建其需要在调用之前保留回数据库的更改列表base.SaveChanges()

This isn't something I've tried to do myself, but it's possible that because you're inside the SaveChanges() method already, the context's changelist has already been created. So when you add your new Contract to the context's Contracts collection, you would have to make your context rebuild its list of changes that need to be persisted back to the database before calling base.SaveChanges()

空宴 2024-11-05 02:28:13

您应该做的是挂钩 SavingChanges ObjectContext 的事件。这将允许您保存到存档/审核表。 这里有一篇文章解释了如何执行此操作。我以前曾经这样做过并且效果非常好。

What you should instead do is to hook into the SavingChanges event of the ObjectContext. This will allow you to save to an archive/audit table. Here is an article that explains how to do it. I've done this before and it works really well.

我爱人 2024-11-05 02:28:13

我正在连接自定义 Context 类(类 MyContext : DbContext ),但它不起作用。

我最终求助于 WCF 数据服务类(类 MyDataService : DataService )并且它运行良好。

I was hooking into the custom Context class ( class MyContext : DbContext ) and it wasn't working.

I finally resorted to hooking into the WCF Data Service class (class MyDataService : DataService ) and it works well.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文