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);
}
子テーブルにあるデータを編集するのではなく、テーブルに新しい行を作成し、親テーブルのGUIDを変更します。親テーブルが正しく編集されています。一対多リレーションシップが子テーブルを編集していない
ご協力いただきますようお願い申し上げます。
を修正したspesifyする必要があります。 _context.Updateメソッドを呼び出す前に_context.Entry(class1.Class2).State = EntityState.Modifiedを実行してみてください。私はclass1.Class2が適切なGUIDセットを持っていると仮定しています – Developer