Hibernate не находит постоянный набор - PullRequest
0 голосов
/ 07 октября 2011

Я читаю из базы данных, используя 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:

Первое отображение модуля:

<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>

Полагаю, ответ будет простым, но если кто-нибудь может мне помочь, я благодарен.

Thanx

1 Ответ

0 голосов
/ 09 октября 2011

По умолчанию 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 здесь .Или посмотрите на пример здесь .

...