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;
}
我認爲我的問題是,當我試圖堅持我的對象,但不確定 。任何幫助表示讚賞。
你在數據庫中看到了什麼?這些實體是否保存在數據庫中? – ujulu
我想是這樣,因爲「find」給了我一個NotfairGenerique;在某些時候,我試圖拋出一個異常,如果檢索到的對象不在數據庫中,但我沒有例外;所以我猜這個實體存儲在數據庫中;我也有其他存儲和檢索沒有問題的實體。 –
你可以在調用'databaseAccess.addForfaitGenerique(forf);'之前和之後發佈'id_f;'的控制檯輸出嗎? – ujulu