public abstract class BaseEntity
{
public Guid Id {get; set;}
}
class EntityA : BaseEntity
{
..other properties..
IList<EntityB> BEntities {get; set;}
}
class EntityB : BaseEntity
{
..other properties..
EntityA Owner {get, set;}
}
映射如下:
<class name="BaseEntity" abstract="true" table="TBL_BaseEntity"
dynamic-insert="true" dynamic-update="true" lazy="true" >
<id name="Id"
column="ID_ENTiTY"
type="guid"
unsaved-value="00000000-0000-0000-0000-000000000000">
<generator class="guid.comb" />
</id>
<discriminator column="EtityType" type="string" force="true" />
</class>
<subclass name="EntityA"
extends="BaseEntity"
discriminator-value="A"
dynamic-insert="true"
dynamic-update="true"
lazy="true">
<join table="TBL_ENTITYA">
<key column="ID_ENTITYA" />
...other mapped properties...
<bag name="BEntities" cascade="save-update"
lazy="true" inverse="true" fetch="select" outer-join="true" >
<key column="ID_ENTITYA" />
<one-to-many class="EntityB"/>
</bag>
</join>
</subclass>
<subclass name="EntityB"
extends="BaseEntity"
discriminator-value="B"
dynamic-insert="true"
dynamic-update="true"
lazy="true">
<join table="TBL_ENTITYB">
<key column="ID_ENTITYB" />
...other mapped properties...
<many-to-one name="Owner" not-null="true"
lazy="proxy" fetch="select" column="ID_ENTITYA" />
</join>
</subclass>
现在的问题是,当我尝试插入并级联一个新的EntityA,其中EntityB的集合已正确初始化(就双向关联而言)一切正常, 但是当我尝试读取EntityA.BEntities集合时,我得到了一个异常,表明NH可以执行查询。 在使用NHProf解决问题后,我看到生成的查询不正确,因为NH将列ID_ENTITYA附加到基表(显然没有该列)而不是 目标已加入子类表。 任何人都可以帮我解决这个问题吗? 我该如何避免这种行为? NH可以这样做吗?
提前致谢。
答案 0 :(得分:1)
我们在这里遇到了同样的问题,我的同事找到了这个解决方案:
在EntityB上创建一个多对一的双向关系,返回到EntityA。
这似乎有助于NH弄清楚EntityA&amp; A之间存在FK关系。 EntityB,而不是BaseEntity&amp; EntityB。
希望这有帮助。
答案 1 :(得分:0)
我最近遇到了同样的问题并提交了一个问题: