我正在使用 Hibernate 从数据库中读取数据。我对它不太熟悉,所以答案可能很简单:
我使用以下简单代码:
public static void main(String[] args) {
CourseHelper ch = new CourseHelper();
Course c = ch.readCourse("fkaea");
for (Module m : c.getModules()) {
for (Question q : m.getQuestions()) {
for (Answer a : q.getAnswers()) {
}
}
}
}
阅读课程后,我可以遍历它的模块,但无法访问持久的问题集。(size = '0') 虽然有问题。
休眠配置文件如下:
首先是模块映射:
<hibernate-mapping>
<class name="hibernate.dao.Module" table="module" catalog="questionnair">
<composite-id name="id" class="hibernate.dao.ModuleId">
<key-property name="idmodule" type="int">
<column name="idmodule" />
</key-property>
<key-property name="idcourse" type="string">
<column name="idcourse" length="12" />
</key-property>
</composite-id>
<many-to-one name="course" class="hibernate.dao.Course" update="false" insert="false" fetch="select">
<column name="idcourse" length="12" not-null="true" />
</many-to-one>
<property name="omschrijving" type="string">
<column name="omschrijving" length="45" />
</property>
<set name="questions" inverse="true">
<key>
<column name="idcourse" />
<column name="idmodule" length="12" />
</key>
<one-to-many class="hibernate.dao.Question" />
</set>
</class>
</hibernate-mapping>
问题映射:
<hibernate-mapping>
<class name="hibernate.dao.Question" table="question" catalog="questionnair">
<id name="idvraag" type="java.lang.Integer">
<column name="idvraag" />
<generator class="identity" />
</id>
<many-to-one name="module" class="hibernate.dao.Module" fetch="select">
<column name="idcourse" />
<column name="idmodule" length="12" />
</many-to-one>
<property name="vraag" type="string">
<column name="vraag" length="245" />
</property>
<set name="answers" inverse="true">
<key>
<column name="idvraag" not-null="true" />
</key>
<one-to-many class="hibernate.dao.Answer" />
</set>
<set name="testquestionses" inverse="true">
<key>
<column name="idquestion" not-null="true" />
</key>
<one-to-many class="hibernate.dao.Testquestions" />
</set>
</class>
</hibernate-mapping>
我想答案很简单,但如果有人能帮助我,我很感激。
谢谢