0

我正在使用 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>

我想答案很简单,但如果有人能帮助我,我很感激。

谢谢

4

1 回答 1

0

默认情况下,当使用列表或集合时,hibernate 不会加载集合。如果需要,通过添加lazy="false"关闭惰性标志。然后在加载模块时将加载所有问题。

   <set name="questions" inverse="true" lazy="false">
        <key>
            <column name="idcourse" />
            <column name="idmodule" length="12" />
        </key>
        <one-to-many class="hibernate.dao.Question" />
    </set>

如果您不想更改映射并希望在此特定场景中加载集合,则可以使用Hibernate.initialize(module.getQuestions()); 在您关闭会话之前。

在此处阅读有关 hibernate 中的集合映射的更多信息。或者看看这里的一个例子。

于 2011-10-09T11:00:03.233 回答