您好我有一个具有复合键和关联对象的实体模型。以下是它的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属性的方法。如果可能,请告诉我。如果还有其他任何问题,请告诉我。任何帮助都会很棒。