我有一个父对象,它包含一个子对象的集合.我想创建一个新的子对象,并将其链接到父对象,通过EF4保存在数据库中
public class Parent
{
public int Id { get; set; }
public string Name { get; set; }
public virtual List<Child> Children { get; set; }
}
到目前为止,我的基本应用程序中发生了什么.我的用户转到显示父对象详细信息的页面,其中包含当前子项的列表.该页面上还有一个链接可添加新的孩子.该链接指向子控制器上的创建操作,传递父ID,父ID又显示视图以创建新子项.这就是我被困住的地方.我不知道如何持久保存提供的父ID,以便当我单击Save时,我可以检索该父对象并将我的新子对象添加到其集合中.
我可能完全以错误的方式接近这个,但我似乎找不到任何关于如何向父项添加新子项的基本教程,考虑到它的常见情况,这很奇怪.
任何帮助真的很感激!
非常感谢
格里
[更新1]
我有两个CreateChild操作,最初由MVC生成,然后由我自己修改.我只能通过观察他们看到他们没有做我需要的东西,但我完全不确定他们需要改变的方式.具体来说,我将父ID存储在ViewBag中,但是在对Create操作的调用之间,它会丢失,因此在调用第二个Create以将新子项持久保存到数据库时不可用.
public ActionResult Create(int parentId)
{
Parent parent = db.Parents.Find(parentId);
ViewBag.ParentId = parent.Id;
return View();
}
[HttpPost]
public ActionResult Create(Child child)
{
if (ModelState.IsValid)
{
Parent parent = db.Parents.Find(ViewBag.ParentId);
parent.Children.Add(child);
db.Children.Add(child);
db.SaveChanges();
return RedirectToAction("Index");
}
return View(child);
}
再次感谢
格里
而不是将其存储在ViewBag中,将其写为子表单中的隐藏字段.然后,当有人提交表单时,ParentId将被提交给您的HttpPost操作方法.
您可以通过在Parent viewmodel上创建ParentId属性来实现此目的.
public class Child
{
public int ParentId { get; set; }
}
public ActionResult Create(int parentId)
{
Parent parent = db.Parents.Find(parentId);
var model = new Child { ParentId = parent.Id };
return View(model);
}
在您的视图中,渲染如下:
@Html.HiddenFor(m => m.ParentId)
然后,在你的HttpPost期间,Child将已经包含ParentId – 默认的模型绑定器将从表单上的隐藏字段中获取它.
[HttpPost]
public ActionResult Create(Child child)
{
if (ModelState.IsValid)
{
Parent parent = db.Parents.Find(child.ParentId);
parent.Children.Add(child);
db.Children.Add(child); // don't think you need this line
db.SaveChanges();
return RedirectToAction("Index");
}
return View(child);
}
发布回答后更新
查看您的HttpPost代码,将子项添加到数据库两次可能不正确.如果您使用的是EF 4.1或4.2,我很确定这是不正确的,但我不确定以前的EF版本.将子项添加到parent.Children集合应该足够了 – 我认为您不应该将它添加到db.Children集合中.
