2016-04-30 341 views
0

這裏是我的實體ForfaitGenerique和Offre。這兩個實體在persistence.xml中(沒有把所有的方法在這裏,如果需要的話我會添加更多的信息):堅持這個對象不會堅持其參數

@Entity 
public class ForfaitGenerique implements Serializable { 

@Id 
@GeneratedValue(strategy = GenerationType.AUTO) 
private int idForfait; 

@NotNull 
private String description = "description"; 


@NotNull 
@OneToMany(cascade = {CascadeType.ALL},fetch = FetchType.LAZY,mappedBy = "forfaitGenerique") 
private List<Offre> listeOffre; 

@NotNull 
@ElementCollection 
List<Integer> listeRemontees; 
//erreur sur mon intellij mais pas d'erreur en faisant mvn clean install.On verra au test 

public ForfaitGenerique() { 

} 
public void addOffre(Offre o) { 
    this.listeOffre.add(o); 
} 

[...] 

@Entity 
public class Offre implements Serializable { 

@NotNull 
private AgeEnum age; 

@Id 
@GeneratedValue(strategy = GenerationType.AUTO) 
private int id; 

@NotNull 
private double nbJour; 

@Enumerated(EnumType.STRING) 
@NotNull 
private SaisonEnum saison; 

@Enumerated(EnumType.STRING) 
@NotNull 
private ReductionEnum reduction; 

boolean consecutif; 

@NotNull 
private double prix; 

@ManyToOne 
private ForfaitGenerique forfaitGenerique; 

public Offre() { 
} 

這裏是我想堅持一個ForfaitGenerique;當我堅持它,然後嘗試通過它的id(這不是空值,似乎有一個很好的價值)檢索它,我得到一個ForfaitGenerique,它不是null,但它應該包含的所有東西是空的(不ID雖然):

@EJB(name="databaseAccess") protected ForfaitsInterface databaseAccess; 
private ForfaitGenerique f; 
private Offre offre_f; 
[...] 
    ArrayList<Integer> l = new ArrayList<>(); 
    l.add(1); 
    l.add(2); 
    l.add(3); 

    ForfaitGenerique forf = new ForfaitGenerique(); 
    List<Offre> l_o = new ArrayList<Offre>(); 
    forf.setListeOffre(l_o); 
    forf.setListeRemontees(l); 
    Offre o = new Offre(forf,AgeEnum.ADULTE,0.5,SaisonEnum.HAUTE,ReductionEnum.FIDELICIME,true,12.0); 
    forf.addOffre(o); 
    databaseAccess.addForfaitGenerique(forf); 
    int id_f = forf.getIdForfait(); 
    assertNotNull(id_f); 
    System.out.println("bloublou"+id_f); 
    f = databaseAccess.getForfaitGenerique(id_f); 
    assertNotNull(f); 
    assertNotNull(f.getListeRemontees());//null !! 

    assertNotNull(f.getListeOffre());//null !! 
    assertEquals(f,forf); 
    offre_f = f.getListeOffre().get(0); 

的databaseAccess對象包含一個EntityManager和兩個方法(以及其他),它們分別是:

@Stateless(name="databaseAccess") 
public class Forfaits implements ForfaitsInterface { 
@PersistenceContext private EntityManager entityManager; 

public void addForfaitGenerique(ForfaitGenerique forfaitGenerique) { 
    entityManager.persist(forfaitGenerique); 
    System.out.println("contains = "+entityManager.contains(forfaitGenerique)); 
} 

@Override 
public void addOffre(Offre o) { 
    entityManager.persist(o); 
} 

public ForfaitGenerique getForfaitGenerique(int id_forfait) { 
    ForfaitGenerique f = entityManager.find(ForfaitGenerique.class,id_forfait);//database.getForfaitFromId(id_forfait); 
    return f; 
} 

我認爲我的問題是,當我試圖堅持我的對象,但不確定 。任何幫助表示讚賞。

+0

你在數據庫中看到了什麼?這些實體是否保存在數據庫中? – ujulu

+0

我想是這樣,因爲「find」給了我一個NotfairGenerique;在某些時候,我試圖拋出一個異常,如果檢索到的對象不在數據庫中,但我沒有例外;所以我猜這個實體存儲在數據庫中;我也有其他存儲和檢索沒有問題的實體。 –

+0

你可以在調用'databaseAccess.addForfaitGenerique(forf);'之前和之後發佈'id_f;'的控制檯輸出嗎? – ujulu

回答

0

事實上,我只是在測試之前忘記添加@Transactional(TransactionMode.COMMIT)。這是愚蠢的解決方案。