Hallo.
ich bin relativ neu in JPA/Hibernate und habe daher folgendes Problem:
Mein Ziel war es bei einer Datenverarbeitung Statusobjekte pro bearbeitendem File anzulegen, diese haben eine Liste mit Logobjekten, nach jedem Schritt wird ein Log-Objekt erzeugt und in die Liste des Statusobjektes gelegt.
Dies soll dann auch in der Datenbank direkt verändert werden.
Ich gehe wie folgt vor:
ich erzeuge mir einen Entitymanger:
Code:
EntityManagerFactory emf;
EntityManager em;
public void init(String unitName)
{
emf = Persistence.createEntityManagerFactory(unitName);
em = emf.createEntityManager();
}
Erzeuge dann das Statusobjekt OHNE Logs und mache dann ein :
Code:
public void persist(Object o)
{
em.persist(o);
em.flush();
}
Danach füge ich dem Statusobjekt immer ein Log dazu und rufe em.flush() auf.
Dies speichert die Logs aber nur flüchtig, wenn das Programm nun abschmieren würde wäre nichts in der Datenbank.
Also muss ich nach JEDEM Logeintrag ein em.commit() aufrufen, dies wiederrum schließt aber die Transaction und ich muss mich wieder teuer zur Datenbank verbinden, das StatusObjekt suchen, ihm wieder den nächsten Log reinknallen und wieder committen.
Das geht vermutlich auch anders ;), die ganze z.B. Session-Sache sieht danach aus, als ob wieder nur am Schluss ein COMMIT kommt und ansonsten wird rollback'ed, Alles oder Nix, das ist ja ansich auch meistens richtig, aber genau das möchte ich eben nicht ;). Ich will eben wirklich jedes kleine Detail bis es kracht. Nach jeder Änderung des Objektes direkt persistenz auf die Datenbank.
Hat vllt. jemand nen Tipp wie ich das anpacken könnte, nen Wink in die richtige Richtung wäre schon ausreichend :)
Vielen Dank schonmal fürs lesen,
mfg
chillum