2

私は 5 つのエンティティ フレームワーク モデルを持っていますが、それらはすべて相互に関係しています。新しいものをデータベースに投稿するのは簡単ですが、PUT リクエストを介してそれらを更新しようとすると、非常に面倒になります。各コレクションに手動でアクセスし、変更内容を更新する必要があります。

        private void updateRelation(Dealer dealer)
    {
        var dealerOld = db.Dealers.Include(d => d.Contacts).Single(d => d.DealerID == dealer.DealerID);
        var contactsNew = dealer.Contacts;
        List<int> contactIds = new List<int>();

        if (dealer.DealerGroup == null ||
            dealerOld.DealerGroup == null ||
            dealer.DealerGroup.DealerGroupID != dealerOld.DealerGroup.DealerGroupID)
        {

            if (dealerOld.DealerGroup != null)
            {
                DealerGroup d = db.DealerGroups.Find(dealerOld.DealerGroupID);
                d.Dealers.Remove(dealerOld);
            }

        }

        updateManyToMany(dealer,dealerOld,contactIds,contactsNew);
    }

    private void updateManyToMany(Dealer dealer, Dealer dealerOld, List<int> contactIds, ICollection<Contact> contactsNew  )
    {

        foreach (var contact in contactsNew)
        {
            contactIds.Add(contact.ContactID);
        }

        foreach (var contact in dealerOld.Contacts.ToList())
        {
            if (!contactIds.Contains(contact.ContactID))
            {
                dealerOld.Contacts.Remove(contact);
            }
        }

        foreach (int contactId in contactIds)
        {
            if (!dealerOld.Contacts.Any(c => c.ContactID == contactId))
            {
                var contact = new Contact() { ContactID = contactId };
                dealerOld.Contacts.Add(contact);
                db.Contacts.Attach(contact);
            }
        }
    }

これを行う簡単な方法はありますか

4

1 に答える 1

0

これに関連する質問は他にもたくさんあります。それまでの間、回避策の回答を選別するのに少し時間を費やすか、より役立つ回答を待つことをお勧めします。

于 2013-07-29T19:18:56.610 に答える