[英]One-To-Many Relationship not editing Child table
public class Class1
{
public Guid Class1ID { get; set; }
public string class1string { get; set; }
public virtual Class2 Class2 { get; set; }
}
public class Class2
{
public Guid Class2ID { get; set; }
public string class2string { get; set; }
}
// POST: Class1/Edit/5
// To protect from overposting attacks, please enable the specific properties you want to bind to, for
// more details see http://go.microsoft.com/fwlink/?LinkId=317598.
[HttpPost]
[ValidateAntiForgeryToken]
public async Task<IActionResult> Edit(Guid id, [Bind("Class1ID,Class2,class1string")] Class1 class1)
{
if (id != class1.Class1ID)
{
return NotFound();
}
if (ModelState.IsValid)
{
try
{
_context.Update(class1);
await _context.SaveChangesAsync();
}
catch (DbUpdateConcurrencyException)
{
if (!Class1Exists(class1.Class1ID))
{
return NotFound();
}
else
{
throw;
}
}
return RedirectToAction("Index");
}
return View(class1);
}
而不是使用Edit更改子表中的数据,而是在表中创建新行并更改父表中的GUID。 父表已正确编辑。
任何帮助将不胜感激。
在第1类中,还应添加与主键属性匹配的外键ID。 EF将了解其相关信息
public class Class1
{
public Guid Class1ID { get; set; }
public string class1string { get; set; }
public Guid? Class2ID { get; set; }
[ForeignKey("Class2ID ")]//probably not needed as names match
public virtual Class2 Class2 { get; set; }
}
public class Class2
{
public Guid Class2ID { get; set; }
public string class2string { get; set; }
}
这样,在更新class1
您只需要检查您是否传递了正确的Class2ID
属性,而不必担心导航对象属性Class2
。
为了节省您需要修饰它,
public async Task<IActionResult> Edit(Class1 class1)
{
...
_context.Entry(class1).State = EntityState.Modified;
await _context.SaveChangesAsync();
我也一直在努力解决这个问题。
当我进行编辑并保存时,我点击了函数public async Task Edit(Guid id,[Bind(“ Class1ID,Class2,class1string”)] Class1 class1) (如您所愿 )-
除class1.Class2.Class2ID外,所有值都是正确的, 该类是空的GUID {00000000-0000-0000-0000-0000-000000000000}
结果,当调用SaveChangesAsync时,EF会为Class2创建一个新记录,而不是按预期更新现有记录。
是因为绑定失败,所以找不到Class2.Class2ID的值。
这是因为Get无法加载此值,因为几乎可以肯定该值不在页面上。
将以下行添加到视图标记中(建议在输入type =“ hidden” asp-for =“ Class1ID”旁边 )
<input type="hidden" asp-for="Class2.Class2ID" />
这应该使绑定起作用。
我希望这有帮助。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.