私はNHibernateにかなり慣れていません。
私は多対多のマッピングを行っています。それらは次のようになります。
public abstract class EntityMapping<T> : ClassMapping<T> where T : Entity
{
public EntityMapping()
{
Id(x => x.Id, map => map.Generator(new IdentityGeneratorDef()));
}
}
public class PersonMapping : EntityMapping<Person>
{
public PersonMapping()
{
Property(x => x.Name);
}
}
public class ParentMapping : JoinedSubclassMapping<Parent>
{
public ParentMapping()
{
Property(x => x.ParentOf);
Key(x => x.Column("ParentId"));
Bag(x => x.Children, map =>
{
map.Cascade(Cascade.All);
map.Table("ParentChildren");
map.Key(x => x.Column("ParentId"));
},
r => r.ManyToMany(rm => rm.Column("ChildId")));
}
}
public class ChildMapping : JoinedSubclassMapping<Child>
{
public ChildMapping()
{
Property(x => x.Toys);
Key(x => x.Column("ChildId"));
Bag(x => x.Parents, map =>
{
map.Cascade(Cascade.All);
map.Table("ParentChildren");
map.Inverse(true);
map.Key(x => x.Column("ChildId"));
},
r=>r.ManyToMany(rm => rm.Column("ParentId")));
}
}
私がする時
var parent = session.Get<Parent>(1);
parent.Children.First(); // Works
追加された子にアクセスできます。ただし、元に戻ろうとすると、次のようになります。
var child = session.Get<Child>(2);
child.Parents.First(); // Doesn't work.
子オブジェクトの親コレクションは空です。
この問題に光を当てることができる人はいますか?
乾杯、
ジェームズ
編集
申し訳ありませんが、次のコードを使用してエンティティを保存および取得します。
using(var session = _sessionFactory.OpenSession())
{
using(var transaction = session.BeginTransaction())
{
var person = new Parent(){Name = "James", ParentOf = 1};
var child = new Child(){ Name="James Jr." Toys = 20 };
person.Children.Add(child);
session.Save(person);
transaction.Commit();
}
}
データを取得するには:
using(var session = _sessionFactory.OpenSession())
{
using(var transaction = session.BeginTransaction())
{
var james = session.Get<Parent>(1);
var child = session.Get<Child>(2);
transaction.Commit();
}
}
get をトランザクションでラップする必要がありますか?
乾杯、
ジェームズ