首先,您不需要两次配置您的关系,您只需要执行一次:
protected override void OnModelCreating(ModelBuilder modelBuilder) { modelBuilder.Entity().HasOne(c => c.Requirement) .WithMany(r => r.Courses) .HasForeignKey(c => c.ReqId); }
第二件事是如果你正在进行查询并且你期望延迟加载相关属性,我恐怕是不可能的.EF 7还不支持延迟加载.如您所见,有一个积压项目跟踪延迟加载.因此,如果您需要加载相关实体,则应使用显式加载Include
方法:
var query= ctx.Courses.Include(c=>c.Requirement).Where(...)...;