[英]Updating child objects when editing parent
我正在努力在“编辑帖子”操作中更新相关实体。
我有一个Job和一个JobNotes模型,如下所示:
public class Job
{
public Job()
{
JobNotes = new List<JobNote>();
}
[Key]
public int JobID { get; set; }
public string jobName { get; set; }
public ICollection<JobNote> JobNotes { get; set; }
}
public class JobNote
{
[Key]
public int JobNoteID { get; set; }
public string Author { get; set; }
public string Note { get; set; }
public Job Job { get; set; }
}
我还使用Fluent API来映射我的关系:
(任何有关我是否正确完成此操作的反馈都非常欢迎!)
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Entity<Job>()
.HasMany(x => x.JobNotes)
.WithOptional(y => y.Job);
}
问题是在我的Post方法中,我的JobNotes对象被添加到了父Job对象,但是没有被保存到数据库中。
[HttpPost]
[ValidateAntiForgeryToken]
public ActionResult Edit(JobViewModel model)
{
if (ModelState.IsValid)
{
var existingJob = db.Jobs
.Include(x => x.JobNotes)
.Single(c => c.JobID == model.Job.JobID);
model.Job.JobNotes.Add(new JobNote
{
Author = "System",
Note = "Job modified by " + User.Identity.Name
});
db.Entry(existingJob).CurrentValues.SetValues(model.Job);
db.SaveChanges();
return RedirectToAction("Details", new { id = model.Job.JobID });
}
}
我做错了什么? 在此先感谢您的帮助。
使用existingJob
的model.Job
而不是model.Job
添加新的JobNote
:
existingJob.JobNotes.Add(...);
调用SaveChanges
,EF将检测到新笔记(基于已附加的existingJob
),并将其添加到上下文中,然后插入数据库中。
顺便说一下,您不需要在此过程中包括现有的注释,因此可以删除.Include(x => x.JobNotes)
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.