Hibernate条件返回包含相同对象的列表

时间:2016-03-02 19:22:16

标签: hibernate hibernate-mapping

我们最近为我们的应用程序将hibernate版本从3.1升级到4.3.1。我面临一个奇怪的问题,错误和相同的对象总是与结果对象相关联。

我有一个ClinicalStudyEvent类,它包含EventFormContext类的集合。当我尝试使用HQL在eventId的基础上获取ClinicalStudyEvent时,hibernate将EventFormContext的同一对象与结果对象相关联。每个偶数都有相同的集合对象。

ClinicalStudyEvent

public class ClinicalStudyEvent implements
        Comparable<ClinicalStudyEvent>
{
.....
private Set<EventFormContext> eventFormContexts = new   LinkedHashSet<EventFormContext>();
......
 }

EventFormContext:

public class EventFormContext extends CSFormContext
{
....
private ClinicalStudyEvent clinicalStudyEvent;
....
}

Hibernate Mappings:

ClinicalStudyEvent

     <set
        name="eventFormContexts"
        table="EVENT_FORM_CONTEXT"
        lazy="false"
        inverse="true"
        cascade="all"
        order-by="IDENTIFIER">
          <key column="CLINICAL_STUDY_EVENT_ID"/>
      <one-to-many class="edu.wustl.clinportal.domain.EventFormContext"/>
    </set>

CSFormContext

 <hibernate-mapping default-lazy="false">
   <class
    name="edu.wustl.clinportal.domain.CSFormContext"
    table="CS_FORM_CONTEXT"
    dynamic-update="false"
    dynamic-insert="false">
............
<joined-subclass
        name="edu.wustl.clinportal.domain.EventFormContext"
        table="EVENT_FORM_CONTEXT" >
        <key column="IDENTIFIER" />
......
<many-to-one 
    name="clinicalStudyEvent"
    class="edu.wustl.clinportal.domain.ClinicalStudyEvent" cascade="none"
    update="true" insert="true" column="CLINICAL_STUDY_EVENT_ID"  />

    </joined-subclass>
</class>

对于每个ClinicalStudyEvent类,我们都获得了EventFormContext类的相同对象。

我还通过更改show_sql参数来检查sql,这也是正确的。 我检查了数据库,所有三个类的表都有主键。

任何指针都会有所帮助。

1 个答案:

答案 0 :(得分:0)

此查询中使用的类和hbm在https://forum.hibernate.org/viewtopic.php?f=1&t=1043003&start=0&hilit=ClinicalStudyEvent

中给出

看起来像hibernate4.3中的一个错误,因为它没有添加连接子类的条件。我通过将lazy更改为true并在需要时显式获取对象来解决它。