Hibernate - 在父表和子表中的列上设置过滤

时间:2012-10-02 22:21:14

标签: java sql hibernate jsf hibernate-mapping

我有NodeNodeData相关联。这些NodeData有修订版,Node有一个列latestRevision,告诉它哪个是最后一个版本。

我正在尝试找出我需要的映射,以便latestRevision中的Node过滤下面的集合。

 <class name="Node" table="RatNodes">
    <id name="id">
        <generator class="native"/>
    </id>
    <set fetch="join" name="nodeDatas" table="RatNodeData" inverse="true" access="field" cascade="all-delete-orphan" order-by="dataOrder asc">
        <key column="nodeID" on-delete="cascade"/>
        <one-to-many class="NodeData"/>
        <filter name="revisionFilter" condition="revision = latestRevision"/>
    </set>
    <property name="questionNumber" access="field"/>
    <property name="type" access="field"/>
</class>
<class name="NodeData" table="RatNodeData">
    <composite-id>
        <key-property name="nodeID" access="field"/>
        <key-property name="key" access="field" column="dataKey"/>
        <key-property name="order" access="field" column="dataOrder"/>
        <key-property name="revision" access="field"/>
    </composite-id>
    <property name="value" access="field" type="EncodedStringUserType" column="dataValue"/>
</class>

启用过滤器时此映射的结果是错误:

Caused by: com.jnetdirect.jsql.JSQLException: Invalid column name 'latestRevision'.

它吐出的查询是:

select nodedatas0_.nodeID as nodeID1_, nodedatas0_.dataKey as dataKey1_, nodedatas0_.dataOrder as dataOrder1_, nodedatas0_.revision as revision1_, nodedatas0_.nodeID as nodeID46_0_, nodedatas0_.dataKey as dataKey46_0_, nodedatas0_.dataOrder as dataOrder46_0_, nodedatas0_.revision as revision46_0_, nodedatas0_.dataValue as dataValue46_0_ from RatNodeData nodedatas0_ where  nodedatas0_.revision = nodedatas0_.latestRevision and nodedatas0_.nodeID=? order by nodedatas0_.dataOrder asc

我可以说这是错误的,因为它在latestRevision上寻找NodeData,但我不确定如何告诉它查看Node。这是休眠的可能吗?如果我只是使用SQL,这似乎是一个非常简单的查询。

2 个答案:

答案 0 :(得分:0)

结束这样做而不是尝试在映射文件中执行此操作:

List datas = session.createCriteria(NodeData.class)
                .add(Restrictions.eq("nodeID", this.id))
                .add(Restrictions.eq("revision", this.latestRevision))
                .list();

我不确定这是否是正确的方法。很想知道映射文件解决方案。

答案 1 :(得分:0)

您尚未将任何过滤器或“latestRevision”定义为filter-param。所以它不会知道实体意味着什么。 尝试使用以下内容。

    

如需进一步帮助,请查看link