我有一个表单,它返回一个FlatSessie对象列表
在我的编辑视图中,我编辑了一些FlatSessie并将它们返回到该List对象中的Post方法。
在我的数据库中我有Sessies,我使用Automapper映射到FlatSessie并返回
现在我无法让linq为我更新数据库。
代码:
[HttpPost]
public ActionResult Sessies(int id, int? modID, int? projID, string schooljaarparam, List<FlatSessie> sl) {
if (ModelState.IsValid) {
foreach (FlatSessie s in sl) { //i run over all FlatSessies which i get
Models.Sessies ses = Mapper.Map<FlatSessie, Sessies>(s); // i map them to the Sessies object
List<Sessies> origReeks = _db.Sessies.Where(p => p.Ses_ID == ses.Ses_ID).ToList(); //i get the original Session by ID. if there is a Session with that ID, if not (the ID will be 0) i do an Insert. if there is i want to do an Update.
if (origReeks.Count > 0) {
//it's an update
UpdateModel(origReeks.First(); //doesnt work
//_db.Sessies.Attach(ses, origReeks.First()); //doesnt work, gives me an error on used ID...
_db.SubmitChanges();
} else {
//no sessies yet, add them, this works.
_db.Sessies.InsertOnSubmit(ses);
_db.SubmitChanges();
}
}
TempData["okmsg"] = "De sessies zijn opgeslagen";
return RedirectToAction("Index");
}
//if not valid, i return the viewdata which i need.
Module m = _db.Modules.First(md => md.Mod_ID == modID.Value);
int antses = m.Mod_AantalSessies.Value;
List<List<SelectListItem>> lpllst = new List<List<SelectListItem>>(antses);
for (int i = 0; i < antses; i++) {
lpllst.Add(MvcApplication.lesplaatsList(schooljaarparam, -1));
}
ViewData["lesplist"] = lpllst;
ViewData["lglist"] = MvcApplication.lesgeverList();
return View(sl);
}
答案 0 :(得分:1)
向UpdateModel(FlatSessie[n]
提供prefix可能有用,其中n与所讨论的模型元素的实际输入名称相匹配),以便它知道要映射到哪些属性对象,但因为你得到的这些列表可能没有。您是否尝试使用匹配的FlatSessie
对象中的数据直接更新检索到的模型?
此外,一旦你开始工作,你可能想为所有插入/更新(循环外)做一个SubmitChanges,这样你就可以在一个事务中包含整个提交。如果有错误需要纠正并重新提交,这将使其更容易 - 因为您不会有一些已经提交的更改导致进一步的潜在错误。