EF代码优先附加和创建代理

4
假设我有一个实体Foo。
public class Foo
{
  public int Id {get;set;}
  public virtual ICollection<Bar> Bars {get;set;}
}

当我从数据库中获取此实体时,实际上会得到一个代理,一切都按照应该的方式工作。
但是,我能否将Foo附加到DbContext并手动创建代理,以便在附加它后Bars不会返回null,而是实际的bar集合?
意思是:
var foo = new Foo { Id = 1 };
Context.Set<Foo>().Attach(foo);
foo = CreateProxyOf(foo);
var countOfBars = foo.Bars.Count();

是否有类似于CreateProxyOf的东西?

2个回答

6

是的,有一种方法,但是你需要使用以下方式来替代Foo的构造函数:

var set = Context.Set<Foo>();
var foo = set.Create();
foo.Id = 1;
set.Attach(foo);
var countOfBars = foo.Bars.Count();

是的!这就是我在寻找的。 - maxlego

0
当您获取所有Foos或单个Foo时,可以告诉EF同时获取bars。例如:
var foos = db.Foos.Include("Bars");

var foo = db.Foos.Include("Bars").Single(f => f.Id == 1);

在 MSDN 上有更多详细信息,请参阅此处。

http://msdn.microsoft.com/en-us/library/bb896272.aspx


我实际上的意思是,如果我创建了变量foo = new Foo { Id = 1 }。那么是否可以将其附加到DbContext,以便Bars不会为null,而是实际的结果集。 - maxlego
Include方法返回的是DbQuery<>对象,它似乎没有Find方法。而实际上,Find方法是在DbSet<>类中定义的。我是否遗漏了什么?Find方法是否也是DbQuery的扩展方法? - Luke Foust
你是正确的 - DbQuery 上没有 Find() 方法 - 我已经更新了代码以反映这一点。 - Sam Huggill

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接