Nullpointerexception初始化hibernate实体的关联

时间:2012-07-12 14:01:01

标签: hibernate tomcat7

您好我有一个具有复合键和关联对象的实体模型。以下是它的hbm.xml

<hibernate-mapping>
<class name="com.mytrits.admin.Mtmdmsgqna" table="mtmdmsgqna" catalog="mtmdadmin">
    <composite-id name="id" class="com.mytrits.admin.MtmdmsgqnaId">
        <key-property name="messageId" type="int">
            <column name="MessageId" />
        </key-property>
        <key-property name="qserialNo" type="java.lang.Integer">
            <column name="QSerialNo" />
        </key-property>
        <key-property name="qsenderId" type="java.lang.Integer">
            <column name="QSenderID" />
        </key-property>
        <key-property name="qtext" type="string">
            <column name="QText" length="1000" />
        </key-property>
        <key-property name="aserialNo" type="java.lang.Integer">
            <column name="ASerialNo" />
        </key-property>
        <key-property name="asenderId" type="java.lang.Integer">
            <column name="ASenderID" />
        </key-property>
        <key-property name="atext" type="string">
            <column name="AText" length="1000" />
        </key-property>
    </composite-id>
    <many-to-one name="mtmduser" class="com.mytrits.admin.Mtmduser" update="false" insert="false" fetch="select">
        <column name="QSenderID" />
    </many-to-one>
    <many-to-one name="mtmdmessages" class="com.mytrits.admin.Mtmdmessages" update="false" insert="false" fetch="select">
        <column name="MessageId" not-null="true" />
    </many-to-one>
</class>

我使用namedQuery获取List,下面是查询

<query name="getQNAforMsg">
    <![CDATA[from Mtmdmsgqna where messageId = :msgId order by qserialNo, aserialNo]]>
</query>

在我的托管bean中,我试图通过列表进行迭代但得到NullPointerException。实体列表的大小()&gt; 0,但是当我尝试访问该对象时(在同一个会话中),它失败并给我一个NullPointerException。从列表中获取的初始对象本身为NULL。下面是我的bean代码

private void buildQATree() {
    try {
        MtmdmsgqnaHome qnasHome = new MtmdmsgqnaHome();
        HibernateUtil.beginTransaction();
        qnaList = qnasHome.findQNAbyMsg(messageId.intValue());
        Iterator it = qnaList.iterator();
        while (it.hasNext()) {
            Mtmdmsgqna mqna = (Mtmdmsgqna) it.next();
            mqna.getId().getMessageId();
            System.out.println("Success");
        }
        HibernateUtil.commitTransaction();
    } catch (Exception ex) {
        if (HibernateUtil.isTransactionActive()) HibernateUtil.rollbackTransaction();
        log.error("Exception fetching Entity Types"+ex);
        FacesContext.getCurrentInstance().addMessage(null, new FacesMessage(FacesMessage.SEVERITY_ERROR, "Error Getting Message Detail", "Error Getting Message Detail"));          
    }               
}

我在项目的另一部分中有类似的情况,但在那里没有类似代码的问题。我不知道这里有什么问题。我也尝试了以下方法来迭代,但得到了同样的问题。

/*          
        for (Mtmdmsgqna mqna : qnaList) {
            Hibernate.initialize(mqna);
            Hibernate.initialize(mqna.getId());
            Hibernate.initialize(mqna.getMtmduser());
        }

* /

/*
        for (int i = 0; i < qnaList.size(); i++) {
            Hibernate.initialize(qnaList.get(i));
            Hibernate.initialize(qnaList.get(i).getId());
            Hibernate.initialize(qnaList.get(i).getMtmduser());
        }

* /

我怀疑,因为复合键本身就是一个单独的类,所以它没有被提取(因为Lazy ='true')而且由于除了多对一之外我没有任何其他元素,所以没有什么是急切地想。所以即使你在DB中有数据,对象也是null。由于主实体对象本身为null,因此我无法通过关联对象进一步导航以进行初始化。我怀疑我必须至少热切地获取复合id数据。我是Hibernate的新手,无法在hbm文件中找到在composite-key上设置lazy-eager属性的方法。如果可能,请告诉我。如果还有其他任何问题,请告诉我。任何帮助都会很棒。

0 个答案:

没有答案