[Javalist] TransactionAttributeType.REQUIRES_NEW
Zoltán Bernát
bernatzoltan at gmail.com
2013. Feb. 3., V, 15:23:38 CET
Mar csak egy kerdes: akkor ez az "elegans"/"kovetendo" megoldas, amit
javasoltal?
Böszörményi Péter <zmblevlist at gmail.com> írta (2013. február 3. 15:20):
> Ott rontod el, hogy lokalisan hivod a deletePic metodust. Ilyenkor nem
> jatszik a tranzakcios proxy. Az egyik megoldas, hogy beinjektalod a beanbe
> onmagat, es azon a beanen hivod a deletePic metodust.
>
>
> On Sun, 03 Feb 2013 15:17:45 +0100, Zoltán Bernát <bernatzoltan at gmail.com>
> wrote:
>
>> Sziasztok!
>>
>> JPA kerdes. Tranzakcio kezeles. A megoldando feladat az lenne, hogy
>> tobb entitast toroljek a DB-bol, de olyan modon, hogy ha valamelyik
>> torles meghiusul (pl foreign key miatt), attol meg a tobbi torles
>> rendben megtortenjen.
>> (azaz egy sikertelen torles ne rollback-elje az egesz procedurat)
>>
>> Ugy gondoltam volna megoldani a dolgot, hogy egy tranzakcioban futo
>> metodusbol ciklusban torlom a kepeket egy masik,
>> TransactionAttributeType.REQUIRES_NEW tranzakcioban.
>>
>> A hibajelenseg az, hogy ha egy torles nem sikerult a deletePic (Pix
>> picEntity) metodusban(pl ConstraintViolationException miatt. (ami
>> rendben is van)), akkor a metodus kovetkezo hivasanal mar
>> TransactionRequiredException kivetel dobodik szinten a deletePic (Pix
>> picEntity) metodusban, es igy az amugy torolheto entitast sem sikerul
>> torolni. Azaz ha csak egy entitas is van, amelyik nem torolheto, az
>> osszes torlese meghiusul.
>>
>> Azt gondolom, elvi hibas a megoldasom, meg azt, hogy a
>> TransactionAttributeType.REQUIRES_NEW pont ilyen esetekre lett
>> kitalalva. Hol benazom el? (Hol ertem felre a
>> TransactionAttributeType.REQUIRES_NEW szerepet)?
>> Koszi!
>>
>> @TransactionAttribute(TransactionAttributeType.REQUIRED)
>> public List<Integer> deletePix(List<Integer> ids){
>> for(Integer id : ids){
>> ...
>> if(deletePic(pixBeanEntity)){
>> ... //sikeres torles
>> }
>> }
>> }
>>
>>
>> @TransactionAttribute(TransactionAttributeType.REQUIRES_NEW)
>> private boolean deletePic (Pix picEntity){
>> try {
>> em.remove(picEntity); //em az EntitiManager
>> //org.hibernate.exception.ConstraintViolationException, ha
>> nem megy a torles a foreign key miatt. Ez az elvart viselkedes.
>> //De: TransactionRequiredException jon akkor is, ha
>> em.flush(); //entitiManager flush
>> // itt tovabbi utasitasok vannak, amikre nem kerul a
>> vezerles, ha a fenti flush() kivetelt dobott
>> } catch (Exception e) {
>> context.setRollbackOnly();
>> return false;
>> }
>> return true;
>> }
>> _______________________________________________
>> Javalist mailing list
>> Javalist at lists.javaforum.hu
>> http://lists.javaforum.hu/mailman/listinfo/javalist
>
>
>
> --
> Üdvözlettel,
> Böszörményi Péter
> _______________________________________________
> Javalist mailing list
> Javalist at lists.javaforum.hu
> http://lists.javaforum.hu/mailman/listinfo/javalist
További információk a(z) Javalist levelezőlistáról