Хорошо, я прочитал статью Фила Хаака о связывании со списком, и у меня это работает нормально при одном просмотре. Но что я застрял, когда делал это с основной записи.
У меня есть действительно простая форма для этого объекта
public class Master
{
public int ID { get; set; }
public string MasterTitle { get; set; }
public virtual IList<Detail> Details { get; set; }
}
public class Detail
{
public int ID { get; set; }
public string DetailName { get; set; }
public virtual Master Master { get; set; }
}
Коллекция форм возвращается с ожидаемыми префиксами:
[0] ""
[1] "ID"
[2] "MasterTitle"
[3] "Details[0].ID"
[4] "Details[0]"
[5] "Details"
[6] "Details[0].DetailName"
[7] "Details[1].ID"
[8] "Details[1]"
[9] "Details[1].DetailName" string
И Controller.UpdateModel (master) связывает все свойства правильно. Но когда я вызываю dbContext.SaveChanges, он выдает следующий sql из sql profiler (код psuedo)
update detail1 set masterID = null
update detail2 set masterID = null
update master set masterName = 'newname'
insert detail1 ...
insert detail2 ...
У меня есть работа, которая работает, но она довольно хакерская, и в настоящее время я не сопоставляю ключи, поэтому это зависит от того, все ли возвращается в правильном порядке. Кроме того, я должен включить все поля, которые я хочу обновить.
public ActionResult Edit(FormCollection collection)
{
try
{
using (var ctx = new PlayContext())
{
var id = int.Parse(collection["ID"]);
Master master = ctx.Master.Find(id);
UpdateModel(master, new [] {"MasterTitle"});
for (int i = 0; i < master.details.Count; i++)
{
UpdateModel(master.details[i], "Details[" + i + "]", new[] { "DetailName" });
}
ctx.SaveChanges();
return View(master);
}
}
catch (Exception e)
{
ModelState.AddModelError("", e);
}
return View();
}
У меня такое ощущение, что UpdateModel каким-то образом удаляет и повторно добавляет дочерние элементы.
Кто-нибудь еще заставил это работать? Конечно, я мог бы добавить полотенце и разобрать имена проиндексированных полей, но я так близко!