假设我有一个带有下一个映射的父集合:
public class A : Entity<A>
{
private readonly IList<B> _bs = new List<B>();
public virtual string AProp { get; set; }
public A(string aprop)
{
AProp = aprop;
}
protected A()
{
}
public virtual IEnumerable<B> Bs
{
get { return _bs; }
}
public virtual void AddBEntity(B bEntity)
{
bEntity.A = this;
_bs.Add(bEntity);
}
}
public class AMap : EntityMap<A>
{
public AMap()
{
Map(x => x.AProp).Not.Nullable();
HasMany(x => x.Bs)
.Access.ReadOnlyPropertyThroughCamelCaseField(Prefix.Underscore)
.Inverse().Cascade.All().AsBag();
}
}
以及下一个子类及其映射:
public class B: Entity<B>
{
public virtual string BProp { get; set; }
public virtual A A { get; set; }
}
public class BMap : EntityMap<B>
{
public BMap()
{
Map(x => x.BProp).Not.Nullable();
References(x => x.A).Cascade.All();
}
}
假设我需要将孩子添加到现有的父母。我希望在 SQL 中插入一个已知的子节点值和父节点的 id。我尝试了不同的映射方法,但我不明白为什么要加载代理的 A 对象来添加孩子,因为 NH 分析器建议我这样做。