#c# #entity-framework #ef-code-first #entity-framework-migrations
#c# #entity-framework #ef-code-first #entity-framework-миграции
Вопрос:
Я пытаюсь узнать, как правильно использовать DbContext в ядре EF. У меня есть класс Team:
public class Team
{
public int ID { get; set; }
public string Name { get; set; }
public bool CanSelfManage { get; set; } = false;
public virtual List<Mileage> Mileages { get; set; }
public IdentityUser Member { get; set; }
public string State { get; set; }
public List<Horse> Horses { get; set; }
}
И класс пробега:
public class Mileage
{
public int ID { get; set; }
public virtual Team Team { get; set; }
public virtual int TeamID { get; set; }
public DateTime Date { get; set; }
public LogType Type { get; set; }
public decimal Miles { get; set; }
public IdentityUser User { get; set; }
public List<Horse> Horses { get; set; }
}
И мой класс DbContext содержит
public DbSet<Team> Teams { get; set; }
public DbSet<Mileage> Mileages { get; set; }
public DbSet<Horse> Horses { get; set; }
public DbSet<SecurityEntry> SecurityEntries { get; set; }
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
base.OnModelCreating(modelBuilder);
modelBuilder.Entity<Mileage>()
.HasOne(t => t.Team)
.WithMany(b => b.Mileages)
.HasForeignKey(t => t.TeamID)
.IsRequired();
modelBuilder.Entity<Horse>()
.HasOne(t => t.Team)
.WithMany(h => h.Horses);
modelBuilder.Entity<Horse>()
.HasMany(m => m.Mileages);
modelBuilder.Entity<Mileage>()
.HasMany(h => h.Horses);
}
Проблема, с которой я сталкиваюсь, заключается в том, что независимо от того, что я делаю, Team.Mileages возвращает значение null и никогда не заполняется.
Если я установлю для списка значение «не сопоставляться», введу DbContext и попытаюсь запустить что-либо вне контекста, это выдаст следующую ошибку:
Вторая операция, запущенная в этом контексте до завершения предыдущей операции
Есть ли что-то вопиющее, чего я не понимаю? Я использую MySQL, если это имеет какое-либо значение.
Ответ №1:
Entity Framework по умолчанию использует отложенную загрузку, вы либо устанавливаете режим ускоренной загрузки и загружаете свои ссылки всегда, либо запрашиваете свои коллекции в запросе базы данных. Пример:
_dbcontext.Team.Include(team => team.Mileages).ToList();
Комментарии:
1. Это не на 100% то, что мне было нужно, но это определенно подтолкнуло меня в правильном направлении, поскольку я действительно не знал, что такое отложенная загрузка. Так что спасибо!