Asp.net の子のビューから、子テーブルで参照されている親テーブルのデータを更新しようとしています。
Fluent Nhibernate を使用してテーブルをマッピングしました。
子テーブルでは、マッピングは次のようになります。
public class ChildMap: ClassMap<Child>
{
public ChildMap()
{
Id(i => i.childID).Not.Nullable();
Map(i => i.childValue1);
Map(i => i.childValue2);
Map(i => i.childValue3);
References(i => i.parent, "parentID").Cascade.All();
}
親テーブルのマッピング:
public class ParentMap: ClassMap<Parent>
{
public ParentMap()
{
Id(i => i.parentID).Not.Nullable();
Map(i => i.parentValue1);
Map(i => i.parentValue2);
Map(i => i.parentValue3);
HasMany(i => i.Child).KeyColumn("childID").Cascade.All().Inverse();
}
}
私のコントローラーでは、このように見えます...
[HttpPost]
public ActionResult Edit(int id, FormCollection collection)
{
try
{
using (var tr = UnitOfWork.CurrentUnitOfWork.BeginTransaction())
{
try
{
var child= Registry.Childs.Get(id);
//This update works
UpdateModel(child, new[] { "childValue1", "childValue2", "childValue3" }, collection.ToValueProvider());
//This update on the parent doesn't work
UpdateModel(child.parent, new[] { "child.parent.parentValue1", "child.parent.parentValue2", "child.parent.parentValue3" }, collection.ToValueProvider());
tr.Commit();
}
catch (Exception)
{
tr.Rollback();
throw;
}
}
return RedirectToAction("Index");
}
catch
{
return View();
}
}
上記のコードでは、子テーブルの値を更新しようとすると機能します。ただし、親テーブルに変更を保存しようとすると、機能しません。
これを修正する方法はありますか?
ありがとう。