Hallo,
ich habe folgendes Problem, bzw. ich weiss nicht zu welchem Zeitpunkt ich die neu erstellten Objekte speichern muss.
Meine Mapping Files:
Code:
<class name="Task" table="Task">
<!-- Primärschlüssel -->
<id name="taskId" type="long">
<column name="TaskId" />
<generator class="identity" />
</id>
<!-- Datenelemente -->
<property name="taskName" type="string">
<column name="TaskName" length="50" not-null="true" />
</property>
<set name="Times" inverse="true" lazy="true">
<key>
<column name="TaskId" not-null="true" />
</key>
<one-to-many class="Time" />
</set>
</class>
Code:
<class name="Time" table="Time">
<!-- Primärschlüssel -->
<id name="TimeId" type="long">
<column name="TimeId" />
<generator class="identity" />
</id>
<!-- Datenelemente -->
<property name="date" type="date">
<column name="Date" length="23" not-null="false" />
</property>
</class>
Die Tabelle "Time" besteht aus dem Primärschlüssel, dem Datenelement "Date" und dem Fremdschlüssel "TaskId" (habe ich nicht gemappt) der auf die "Task" Tabelle zeigt.
Sprich, eine einfache 1 : n Beziehung zwischen den Tabellen; ein Task hat mehrere Time.
Jetzt möchte ich ein neues Task Objekt mit 2 Time Objekten erstellen:
Code:
- Begin Transaction -
Task task = new Task();
task.setTaskName("Test1");
HashSet<Time> set = new HashSet<Time>();
Time t1 = new Time();
t1.setDate(...);
set.add(t1);
Time t2 = new Time();
t2.setDate(...);
set.add(t2);
task.setTimes(set);
session.save(task);
- Commit Transaction -
Mein Problem ist jetzt daß das Task Objekt der Datenbank hinzugefügt wurde aber die 2 Time Objekte nicht. Ich dachte das die 2 Time Objekte automatisch mitgepseichert werden da sie ja dem Task Objekt hinzugefügt wurden.
Wenn ich noch session.save(t1) und session.save(t2) einfüge bekomme ich die Fehlermeldung daß das Fremdschlüsselfeld "TaskId" in der Time Tabelle leer ist.
Gibt es generell eine Vorgehensweise um neue Objekte anzulegen die ein Set als Datenelement haben??
Danke schonmal im Voraus
Gruß
Matze