我正在使用EF 5和Code First。我有一个类,我想总是急于加载一些属性。我删除了虚拟关键字,但它并不急于加载:
public class Person
{
public ICollection<Email> Emails { get; set; }
public Profile Profile {get;set;}
}
因此,通过关闭延迟加载,它不会自动急切加载吗?如果是这样,如何在不使用Include()的情况下归档?
谢谢!
答案 0 :(得分:18)
不,通过删除virtual
关键字来关闭延迟加载不会自动启用急切加载。您必须Include
相关的Entity
或Collection
,如此:
var personWithProfile = ctx.People.Include(x => x.Profile).First();
var personWithProfileAndEmails = ctx.People.
.Include(x => x.Profile)
.Include(x => x.Emails)
.First();
这是来自ADO.NET团队博客的精彩内容:http://blogs.msdn.com/b/adonet/archive/2011/01/31/using-dbcontext-in-ef-feature-ctp5-part-6-loading-related-entities.aspx