2016-04-30 126 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)。这是愚蠢的解决方案。