EF 7: cómo cargar entidades relacionadas en una relación uno a varios

asp.net asp.net-core c# entity-framework entity-framework-core

Pregunta

tengo el siguiente código. ¿Por qué mis propiedades de navegación (Requisito en curso y Cursos en requisito) son nulas?

    public class Course : AbsEntity {
            [Key]
            public string Title { get; set; }
            public string Term { get; set; }
            public int Year { get; set; }
            public string CourseId { get; set; }        
            public double GradePercent { get; set; }        
            public string GradeLetter { get; set; }     
            public string Status { get; set; }
            public int ReqId { get; set; }

            public Requirement Requirement { get; set; }
        }

    public class Requirement : AbsEntity {
            [Key]
            public int ReqId { get; set; }
            public string ReqName { get; set; }

            public ICollection<Course> Courses { get; set; }
        }

// In DbContext
    protected override void OnModelCreating(ModelBuilder modelBuilder)
            {
                modelBuilder.Entity<Course>().HasOne(c => c.Requirement).WithMany(r => r.Courses).HasForeignKey(c => c.ReqId);
                modelBuilder.Entity<Requirement>().HasMany(r => r.Courses).WithOne(c => c.Requirement);
            }

Respuesta aceptada

Lo primero es que no necesita configurar su relación dos veces, solo necesita hacerlo una vez:

protected override void OnModelCreating(ModelBuilder modelBuilder)
{
   modelBuilder.Entity<Course>().HasOne(c => c.Requirement)
                                .WithMany(r => r.Courses)
                                .HasForeignKey(c => c.ReqId);          
}

Lo segundo es que si está haciendo una consulta y espera cargar de forma perezosa las propiedades relacionadas, me temo que no será posible. EF 7 no soporta la carga perezosa todavía. Como puede ver, hay un elemento de seguimiento de seguimiento de carga diferida. Por lo tanto, si necesita cargar una entidad relacionada, debe usar la carga explícita utilizando el método Include :

protected override void OnModelCreating(ModelBuilder modelBuilder)
{
   modelBuilder.Entity<Course>().HasOne(c => c.Requirement)
                                .WithMany(r => r.Courses)
                                .HasForeignKey(c => c.ReqId);          
}



Licencia bajo: CC-BY-SA with attribution
No afiliado con Stack Overflow
¿Es esto KB legal? Sí, aprende por qué
Licencia bajo: CC-BY-SA with attribution
No afiliado con Stack Overflow
¿Es esto KB legal? Sí, aprende por qué