实体框架4.1 - 如何“强制”EF转到数据库而不是使用图形?

时间:2011-10-12 04:33:39

标签: c# entity-framework entity-framework-4 entity-framework-ctp5

这是方案,我有一个网站,在一个HTTP请求(HTTP POST)中,我需要执行以下操作:

  1. 抓住一个物体(让我们说“标签”)
  2. 保存其他一些对象(让我们说“问题”)
  3. 获取“Tag”的新副本。
  4. 重定向到另一个页面,需要一份“Tag”的新副本。
  5. 在幕后,2)涉及影响“标签”数据的数据库端触发器。

    所以当我做3)时,EF正在从步骤1)中拉出对象的相同副本,因为它在图形/内部存储器中(例如,相同的连接/上下文)

    我需要一个“新鲜”的对象副本。

    过去,我使用Detach,然后执行EF查询,并从数据库中获取最新的对象。

    但我本身无法访问该对象(我有一个DTO,它从我的存储库返回),所以我没有任何东西要传递给Detach方法。 / p>

    有什么方法可以说:

    var fresh = db.Tags.Find(1, ignoreGraph: true)
    

    还是有另一种选择吗?

    如上所述,我在实体框架4.1,C#4(和ASP.NET MVC 3)

    我现在能看到的唯一解决方案是将查询字符串参数传递给下一页,然后抓取新副本(因为它是新的上下文,新图等)。

1 个答案:

答案 0 :(得分:13)

找到我的答案,我想:

Context.Entry<T>(entity).Reload()

现在尝试......