我的问题类似于这个问题。但是我想通过与一对一关系关联的子实体的鉴别器进行查询,并且不知道确切的鉴别器值,即按类型而不是按字符串。
给定一个像这样的 hbm:
<class name="Parent" table="ParentTable">
<id name="Id">
<generator class="guid.comb" />
</id>
<one-to-one name="Child" class="IChild" property-ref="Parent" cascade="all" />
</class>
<class name="IChild" table="ChildTable" abstract="true">
<id name="Id">
<generator class="foreign">
<param name="property">Parent</param>
</generator>
</id>
<discriminator column="TypeKey" type="String"/>
<one-to-one name="Parent" class="Parent" />
</class>
<subclass name="ConcreteChild" extends="IChild" discriminator-value="Concrete1">
<property name="SomeProperty"/>
</subclass>
或任何其他一对一配置,我想运行类似这样的查询:
public IEnumerable<Parent> FindByChild(Type childType)
{
return session.CreateCriteria<Parent>()
.Add(Restrictions.Eq("Child.class", childType))
.List<Parent>();
}
更多信息:
上述条件查询失败,因为“Child.class”未被识别为有效。
使用 HQL 的类似查询失败,因为 NHibernate 在查询中使用 childType 的全名而不是其鉴别器值。