5

我已将我的应用程序从 EF4 迁移到 EF5。我将以下代码与以前的版本一起使用来获取新添加项目的相关实体。

Student s = new Student();
s.Name = _name;
s.ClassID = _cID;

db.Students.Add(s);
db.SaveChanges();

ClassRoom c = s.ClassRoom;

所以我曾经将特定的类实体获取到c. 但现在s.ClassRoom返回 null。

如何ClassRoom为学生获取实体?我必须使用db.ClassRooms.FirstOrDefault(....)吗?

4

1 回答 1

9

问题是您尚未加载导航属性。

您可以使用:

db.Students.Include("ClassRoom")

或者

using System.Data.Entity;
db.Students.Include(s=>s.ClassRoom)

急切地加载导航属性

另一种选择是通过将导航属性标记为虚拟来启用延迟加载。我个人更喜欢前者(渴望加载),因为它鼓励更高性能的代码。

还可以在这里查看我的导航属性文章,我谈到在开始附近加载http://blog.staticvoid.co.nz/2012/7/17/entity_framework-navigation_property_basics_with_code_first

您的代码应如下所示:

Student s = new Student();
s.Name = _name;
s.ClassID = _cID;

db.Students.Add(s);
db.SaveChanges();

//reload the entity from the DB with its associated nav property
s = db.Students.Include(s=>s.ClassRoom).Single(st=>st.StudentId == s.StudentId);
ClassRoom c = s.ClassRoom;
于 2013-09-05T07:06:54.970 回答