我与两张桌子有一对多关系,Parent
有很多Child
。 我创建一个父项并向其添加子项。然后,我创建它(如果它是一个新父项)或更新它(如果它已经存在)。创建它时,一切正常。但是,如果我更新它,孩子们不会更新。如何更新实体框架中的子表?
using (var Repo = new ParentRepository(context))
{
var key = new AnnualFormKey(prnt.Year, prnt.UserId);
if (Repo.Retrieve(key) == null)
{
prnt.CreatedDate = DateTime.Now;
prnt.CreatedId = 1;
Repo.Create(prnt);
Repo.SaveChanges(); //creates parent and children
}
else
{
prnt.UpdatedDate = DateTime.Now;
prnt.UpdatedId = 2;
Repo.Update(prnt);
Repo.SaveChanges(); //updates parent but not children
}
}
(注:更新调用_context.Entry(orginal).CurrentValues.SetValues(entity)
这是我的上下文中的问题,或者我需要做些别的事情
只需提及:不幸的是,在大多数情况下,您需要“复杂的变通办法”,因为您不能总是删除旧的实体,因为数据库中可能有其他实体引用父或子外键约束或因为您想保留一些列值不变,只更新其他一些列。你有幸在你的情况下:) – Slauma 2012-08-07 22:26:21