EF Code First强制急切加载

时间:2012-08-22 00:32:34

标签: entity-framework ef-code-first code-first

我正在使用EF 5和Code First。我有一个类,我想总是急于加载一些属性。我删除了虚拟关键字,但它并不急于加载:

public class Person
{
   public ICollection<Email> Emails { get; set; } 
   public Profile Profile {get;set;}
}

因此,通过关闭延迟加载,它不会自动急切加载吗?如果是这样,如何在不使用Include()的情况下归档?

谢谢!

1 个答案:

答案 0 :(得分:18)

不,通过删除virtual关键字来关闭延迟加载不会自动启用急切加载。您必须Include相关的EntityCollection,如此:

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