使用Linq将List <t>对象更新为DB </t>

时间:2010-03-16 15:22:52

标签: linq-to-sql asp.net-mvc-2 updatemodel

我有一个表单,它返回一个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);
    }

1 个答案:

答案 0 :(得分:1)

向UpdateModel(FlatSessie[n]提供prefix可能有用,其中n与所讨论的模型元素的实际输入名称相匹配),以便它知道要映射到哪些属性对象,但因为你得到的这些列表可能没有。您是否尝试使用匹配的FlatSessie对象中的数据直接更新检索到的模型?

此外,一旦你开始工作,你可能想为所有插入/更新(循环外)做一个SubmitChanges,这样你就可以在一个事务中包含整个提交。如果有错误需要纠正并重新提交,这将使其更容易 - 因为您不会有一些已经提交的更改导致进一步的潜在错误。