ASP MVC - 多对多的关系

时间:2011-02-16 22:14:55

标签: asp.net-mvc entity-framework

我老老实实地找了一个多小时才能得到满意的答案。所以并不是我没有找到答案,而是我认为不完全正确的答案。这可能仅仅意味着我正在寻找一个不存在的银弹。

在包含多对多关系的EF(代码优先)模型的asp mvc中,如何将该关系绑定到复选框,然后将这些更改优雅地传播到我的数据库。

如果视图仅返回已选中复选框的值,则我不再知道先前检查过哪些值。我是否再次拉回原始物体然后比较两者?它感觉很脏,可能是因为我已经习惯让EF魔法管理对象上已经改变的属性。

我已经有了一个我不满意的脏版本。

    [HttpPost]
    public ActionResult Edit(int id, FormCollection collection)
    {
        try
        {
            // TODO: Add insert logic here
            Program p = _programRep.GetByID(id);

            //manually update properties
            //change to model binding later


            EditPolicies(ref p, collection["SelectedPolicies"].ToString().Split(','));

            _programRep.Save(p);

            return RedirectToAction("Index");
        }
        catch
        {
            return View();
        }
    }

    private void EditPolicies(ref Program c, string[] selectedvals)
    {
        //I could do comparison logic here 
        int count = c.Policies.Count;
        for (int i = 0; i < count; i++)
        {
            c.Policies.Remove(c.Policies.ElementAt(0));
        }

        for (int i = 0; i < selectedvals.Count(); i++)
        {
            Policy g = _policyRep.GetByID(int.Parse(selectedvals[i]));
            c.Policies.Add(g);
        }
    }

1 个答案:

答案 0 :(得分:1)

我不太确定你对此的期望如何,所以我不知道你在寻找什么,但这是正确的方法和设计。

有很多建模案例。希望我保存了我发现的完美示例中的链接,其中从集合中删除对象只是意味着缺少关系而不是需要删除行。

我要添加的唯一优雅是:

 c.Policies.AddRange(_policyRep.GetByIDs(selectedvals[i]));