0

我的问题类似于这个问题。但是我想通过与一对一关系关联的子实体的鉴别器进行查询,并且不知道确切的鉴别器值,即按类型而不是按字符串。

给定一个像这样的 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 的全名而不是其鉴别器值。

4

1 回答 1

3

您是否尝试过使用别名?我现在无法在我的机器上测试它,但应该与此类似..

return session.CreateCriteria<Parent>()
                .CreateAlias("ParentChild","Child")
                .Add(Restrictions.Eq("ParentChild.class", childType))
                .List<Parent>();

其中 ParentChild 只是我用来指代 Parent 类的 Child 实体的名称

于 2013-06-24T21:39:56.423 回答