|
|
|
![]() |
|
Strumenti |
![]() |
#1 |
Senior Member
Iscritto dal: Sep 2003
Città: Milano
Messaggi: 4623
|
[JAVA] Hibernate e Lazy Loading... problema
Ragazzi, nella mia applicazione uso Hibernate attraverso JPA.
Quando accedo ad una entità ritornata da un EJB ( uso gli entity come datamodel, non faccio uso di DTO ) succede che: Se le relazioni sono configurate con fetch LAZY: @OneToMany(mappedBy="id_tabella", cascade = CascadeType.ALL, fetch = FetchType.LAZY non mi carica tutto l'oggetto ( la relazione uno a molti è null ) perchè evidentemente non accedo a quella proprietà prima di ritornarla dall'EJB Se le relazioni sono configurate come EAGER @OneToMany(mappedBy="id_tabella", cascade = CascadeType.ALL, fetch = FetchType.EAGER Mi carica l'oggetto ma o mi va in stackoverflow o nella migliore delle ipotesi ho dati duplicati ( visto che EAGER attiva la relazione come left outher join, al posto di select ) Come si risolve a questo problema??
__________________
Ho trattato con : lahiri, czame, RC, allXXX, dfruggeri, JMM, Paperone, xej, Pappez, iperfly, Red81, Playmake, ryan78, Rob66, XP2200, Peach1200, faberjack, Stewie82, supermario_bros, hft500, Axelscorpio, pipes lee, Piccolospazio, RohanKish, miki66, kabira85 |
![]() |
![]() |
![]() |
#2 |
Member
Iscritto dal: Feb 2008
Messaggi: 269
|
ti sei ricordato di usare l'annotation @ManyToOne nell'altra classe?
__________________
CPU: AMD Athlon X2 7750BE 3.15Ghz@vcore 1.3750 / NorthBridge: 2250Mhz@1.3125v RAM: Mushkin XP2 Radioactive 4GB 900Mhz@4-4-4-12-1T / HyperTransport: 2025Mhz VGA: Club3D Radeon HD4850 / HDD: Western Digital Caviar RE3 |
![]() |
![]() |
![]() |
#3 |
Senior Member
Iscritto dal: Sep 2003
Città: Milano
Messaggi: 4623
|
si, gli entity sono stati autogenerati
__________________
Ho trattato con : lahiri, czame, RC, allXXX, dfruggeri, JMM, Paperone, xej, Pappez, iperfly, Red81, Playmake, ryan78, Rob66, XP2200, Peach1200, faberjack, Stewie82, supermario_bros, hft500, Axelscorpio, pipes lee, Piccolospazio, RohanKish, miki66, kabira85 |
![]() |
![]() |
![]() |
#4 |
Member
Iscritto dal: Feb 2008
Messaggi: 269
|
d'accordo, quindi il problema non è li. proviamo qualcos'altro:
@OneToMany(mappedBy="id_tabella", cascade = CascadeType.ALL, fetch = FetchType.LAZY La proprietà a cui appartiene quest'annotazione è una lista vero?
__________________
CPU: AMD Athlon X2 7750BE 3.15Ghz@vcore 1.3750 / NorthBridge: 2250Mhz@1.3125v RAM: Mushkin XP2 Radioactive 4GB 900Mhz@4-4-4-12-1T / HyperTransport: 2025Mhz VGA: Club3D Radeon HD4850 / HDD: Western Digital Caviar RE3 |
![]() |
![]() |
![]() |
#5 |
Senior Member
Iscritto dal: Sep 2003
Città: Milano
Messaggi: 4623
|
si esatto
__________________
Ho trattato con : lahiri, czame, RC, allXXX, dfruggeri, JMM, Paperone, xej, Pappez, iperfly, Red81, Playmake, ryan78, Rob66, XP2200, Peach1200, faberjack, Stewie82, supermario_bros, hft500, Axelscorpio, pipes lee, Piccolospazio, RohanKish, miki66, kabira85 |
![]() |
![]() |
![]() |
#6 |
Member
Iscritto dal: Feb 2008
Messaggi: 269
|
escludiamo anche quello allora.
senza qualche informazione in più ora diventa difficile aiutarti... se tu lo lasci Lazy, la prima volta che usi in qualche modo la lista Hibernate dovrebbe riempirla automaticamente con tutti gli oggetti relazionati. Confermi che funziona? In che senso dati duplicati? Che la lista contiene un doppione di ogni oggetto?
__________________
CPU: AMD Athlon X2 7750BE 3.15Ghz@vcore 1.3750 / NorthBridge: 2250Mhz@1.3125v RAM: Mushkin XP2 Radioactive 4GB 900Mhz@4-4-4-12-1T / HyperTransport: 2025Mhz VGA: Club3D Radeon HD4850 / HDD: Western Digital Caviar RE3 |
![]() |
![]() |
![]() |
#7 | |
Senior Member
Iscritto dal: Sep 2003
Città: Milano
Messaggi: 4623
|
Quote:
Quando si passa a EAGER ( e io devo usare questa perchè il mio chiamante utilizza i dati che gli passo una volta chiusa la transazione JTA che ha estratto i dati, che però io non ho mai utilizzato, ma che ritorno così come sono ) la modalità di estrazione passa da SELECT a JOIN ( per questo essendo una left outher join mi mostra duplicati nella relazione uno a molti, dove la cardinalità è esattamente il numero di tuple estratte ). Detto questo mi è bastato aggiungere al mio entity la annotation @Fetch(FetchMode.SELECT) In modo da ripristinare il fetch mode a select. Ho visto questa cosa semlicemente abilitando i log di hibernate che mi scrive ora tutte le query che esegue. Sinceramente non sono sicuro al 100% che questa soluzione sia la cosa corretta.... ma funziona!
__________________
Ho trattato con : lahiri, czame, RC, allXXX, dfruggeri, JMM, Paperone, xej, Pappez, iperfly, Red81, Playmake, ryan78, Rob66, XP2200, Peach1200, faberjack, Stewie82, supermario_bros, hft500, Axelscorpio, pipes lee, Piccolospazio, RohanKish, miki66, kabira85 |
|
![]() |
![]() |
![]() |
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 11:14.