J'ai vu quelques questions liées au sujet, mais je n'ai pas trouvé de réponse pour ce scénario.Meilleure pratique pour mettre à jour des entités associées dans ASP.NET MVC + EF4 sans charger d'entité en premier
Je structure comme
Une partie de mon contrôleur
//
// GET: /Person/Edit/5
public ActionResult Edit(int id)
{
var viewModel = new PersonViewModel(PersonRepository.Get(id));
return View(model);
}
//
// POST: /Person/Edit
[AcceptVerbs(HttpVerbs.Post)]
public ActionResult Edit(PersonViewModel model)
{
PersonRepository.Update(model.Person, model.Phones);
return RedirectToAction("Index");
}
Dans mon dépôt im faire quelque chose comme ceci:
public void Update(Person person, ICollection<Phone> phones)
{
using (var unitOfWork = UnitOfWork.Current)
{
Attach(contact);
UpdatePhones(contact, phones);
unitOfWork.Commit();
}
}
public Person Attach(Person person)
{
Context.AttachTo("Persons", entity);
Context.ObjectStateManager.ChangeObjectState(entity, EntityState.Modified);
return entity;
}
public void UpdatePhones(Person person, ICollection<Phone> phones)
{
if (phones == null || phones.Count == 0) return;
foreach (var phone in phones.Where(o => o.IsDeleted && !o.IsNew))
{
PhoneRepository.Delete(phone);
}
foreach (var phone in phones.Where(o => !o.IsDeleted && o.IsNew))
{
party.Phones.Add(phone);
}
foreach (var phone in phones.Where(o => !o.IsDeleted && !o.IsNew))
{
phone.PartyID = party.ID;
PhoneRepository.Attach(phone);
}
}
IsDeleted et ISNEW ne sont pas conservées dans db et utilisé sous forme dynamique. PhonesRepository Attach() est identique.
Im faisant toutes mes mises à jour comme ceci parce que je dois réduire le nombre d'appels de DB autant que possible. Peut-être qu'il existe une meilleure pratique connue pour cela?
Merci =)