Как правильно установить отношения многие ко многим с EF6? - PullRequest
0 голосов
/ 24 января 2020

У меня есть некоторые проблемы с установлением отношений между многими и многими. У меня есть две таблицы, Beestje и Accessoire, и я хочу показать их содержимое.

Это мои таблицы: Beestje:

public class Beestje
{
    public Beestje()
    {
        this.Accessoires = new HashSet<Accessoire>();
    }

    [Key]
    public int Id { get; set; }

    public String Naam { get; set; }

    public String Type { get; set; }

    public int Prijs { get; set; }

    public String Afbeelding { get; set; }

    public virtual ICollection<Accessoire> Accessoires { get; set; }
}

Accessoire:

public class Accessoire
{
    public Accessoire()
    {
        this.Beestjes = new HashSet<Beestje>();
    }

    [Key]
    public int Id { get; set; }

    public String Naam { get; set; }

    public double Prijs { get; set; }

    public String Afbeelding { get; set; }

    public virtual ICollection<Beestje> Beestjes { get; set; }
}

В моем контроллере я извлекаю содержимое из таблицы Beestje и возвращаю его в представление:

public ActionResult Beestjes()
    {
        ViewBag.Message = "Your application beestjes page";

        List<Beestje> beestjes;

        using (var context = new MyContext())
        {
            beestjes = context.Beestjes.ToList();

            return View(beestjes);
        }
    }

Когда я печатаю это так, проблем не возникает:

@model IEnumerable<BeestjeOpJeFeestje.Models.Beestje>

<h2>@ViewBag.Message</h2>
<ul>
    @foreach (var a in Model)
    {
        <li>@a.Naam</li>
    }
</ul>

Но когда я напечатайте это так, я получаю сообщение об ошибке:

@model IEnumerable<BeestjeOpJeFeestje.Models.Beestje>

<h2>@ViewBag.Message</h2>
<ul>
    @foreach (var a in Model)
    {
        <li>@a.Naam</li>
        foreach (var b in a.Accessoires)
        {
            <li>@b.Naam</li>
        }
    }
</ul>

В той части, где я вызываю a.Accessoires, происходит ошибка. Ошибка: «System.ObjectDisposedException:« Экземпляр ObjectContext был удален и больше не может использоваться для операций, требующих подключения. »*

Кто-то знает правильный путь и хотел бы предоставить мне правильный код, или дать мне несколько указаний?

Спасибо заранее.

РЕДАКТИРОВАТЬ:

MyContext

public class MyContext : DbContext
    {
        public MyContext() : base("name=Local")
        {
            Database.SetInitializer(new MyContextInitializer());
        }

        public DbSet<Beestje> Beestjes { get; set; }
        public DbSet<Accessoire> Accessoires { get; set; }

        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            base.OnModelCreating(modelBuilder);
        }
    }

MyContextInitializer

public class MyContextInitializer : DropCreateDatabaseAlways<MyContext>
    {
        protected override void Seed(MyContext context)
        {
            base.Seed(context);

            context.Beestjes.Add(new Beestje() { Id = 1, Naam = "Aap", Type = "Jungle", Prijs = 150, Afbeelding = "Content/images/aap.png" });
            context.Beestjes.Add(new Beestje() { Id = 2, Naam = "Olifant", Type = "Jungle", Prijs = 250, Afbeelding = "Content/images/olifant.png" });
            context.Beestjes.Add(new Beestje() { Id = 3, Naam = "Zebra", Type = "Jungle", Prijs = 200, Afbeelding = "Content/images/zebra.png" });
            context.Beestjes.Add(new Beestje() { Id = 4, Naam = "Leeuw", Type = "Jungle", Prijs = 250, Afbeelding = "Content/images/leeuw.png" });
            context.Beestjes.Add(new Beestje() { Id = 5, Naam = "Hond", Type = "Boerderij", Prijs = 75, Afbeelding = "Content/images/doggo.png" });
            context.Beestjes.Add(new Beestje() { Id = 6, Naam = "Ezel", Type = "Boerderij", Prijs = 150, Afbeelding = "Content/images/donkey.png" });
            context.Beestjes.Add(new Beestje() { Id = 7, Naam = "Koe", Type = "Boerderij", Prijs = 100, Afbeelding = "Content/images/koe.png" });
            context.Beestjes.Add(new Beestje() { Id = 8, Naam = "Eend", Type = "Boerderij", Prijs = 50, Afbeelding = "Content/images/duck.png" });
            context.Beestjes.Add(new Beestje() { Id = 9, Naam = "Kuiken", Type = "Jungle", Prijs = 35, Afbeelding = "Content/images/kuiken.png" });
            context.Beestjes.Add(new Beestje() { Id = 10, Naam = "Pinguin", Type = "Sneeuw", Prijs = 175, Afbeelding = "Content/images/pingwing.png" });
            context.Beestjes.Add(new Beestje() { Id = 11, Naam = "IJsbeer", Type = "Sneeuw", Prijs = 300, Afbeelding = "Content/images/ijsbeer.png" });
            context.Beestjes.Add(new Beestje() { Id = 12, Naam = "Zeehond", Type = "Sneeuw", Prijs = 200, Afbeelding = "Content/images/zeehond.png" });
            context.Beestjes.Add(new Beestje() { Id = 13, Naam = "Kameel", Type = "Woestijn", Prijs = 175, Afbeelding = "Content/images/kameel.png" });
            context.Beestjes.Add(new Beestje() { Id = 14, Naam = "Slang", Type = "Sneeuw", Prijs = 125, Afbeelding = "Content/images/slang.png" });

            var accessoire1 = new Accessoire() { Naam = "Banaan", Prijs = 0.50 };
            accessoire1.Beestjes.Add(context.Beestjes.Find(1));
            context.Accessoires.Add(accessoire1);

            var accessoire2 = new Accessoire() { Naam = "Zadel", Prijs = 4.50 };
            accessoire2.Beestjes.Add(context.Beestjes.Find(3));
            context.Accessoires.Add(accessoire2);

            var accessoire3 = new Accessoire() { Naam = "Krukje", Prijs = 5 };
            accessoire3.Beestjes.Add(context.Beestjes.Find(4));
            context.Accessoires.Add(accessoire3);

            var accessoire4 = new Accessoire() { Naam = "Zweep", Prijs = 2.50 };
            accessoire4.Beestjes.Add(context.Beestjes.Find(4));
            context.Accessoires.Add(accessoire4);

            var accessoire5 = new Accessoire() { Naam = "Bal", Prijs = 2.50 };
            accessoire5.Beestjes.Add(context.Beestjes.Find(5));
            accessoire5.Beestjes.Add(context.Beestjes.Find(12));
            context.Accessoires.Add(accessoire5);

            var accessoire6 = new Accessoire() { Naam = "Dansschoenen", Prijs = 3.00 };
            accessoire6.Beestjes.Add(context.Beestjes.Find(10));
            context.Accessoires.Add(accessoire6);

            context.SaveChanges();
        }
    }

1 Ответ

2 голосов
/ 24 января 2020

Скорее всего, это связано с тем, что для каждого Beestje свойство Accessoires не загружается, пока вы не попытаетесь получить к нему доступ в представлении, и в этот момент MyContext уже удалено.

Решение состоит в том, чтобы сообщить EF немедленно загрузить их, используя .Include(), который известен как 'готовая загрузка':

using (var context = new MyContext())
{
    beestjes = context.Beestjes
        .Include("Accessoires")
        .ToList();

    return View(beestjes);
}

Для справки см. https://docs.microsoft.com/en-us/ef/ef6/querying/related-data

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...