lundi 11 mai 2015

JPA/Hibernate - JEE - Unable to find model.Composer with id model.ComposerId@0

I'm trying to persist in my DB a COMMANDE object (sorry it's in french ;)). My DB : Description of my BD Here is my mapping : composer.java:

package model;

import java.io.Serializable;

import javax.persistence.*;

import model.Panier;
import model.Produit;

/**
 * Entity implementation class for Entity: Composer
 *
 */
@Entity
@Table(name="COMPOSER")
@IdClass(ComposerId.class)

public class Composer implements Serializable {

    @Id
    private int idPan;
    @Id
    private int idProd;

    @ManyToOne
    //@PrimaryKeyJoinColumn(name="idPan", referencedColumnName="id")
    @JoinColumn(name="idPan", referencedColumnName="id", insertable = false, updatable = false)
    private Panier panier;

    @ManyToOne
    //@PrimaryKeyJoinColumn(name="idProd", referencedColumnName="id")
    @JoinColumn(name="idProd", referencedColumnName="id" , insertable = false, updatable = false)
    private Produit produit;
    private int nbProdPan;
    private static final long serialVersionUID = 1L;

    public Composer() {
        super();
    }   
    public Panier getPanier() {
        return this.panier;
    }

    public void setPanier(Panier panier) {
        this.panier = panier;
    }   
    public Produit getProduit() {
        return this.produit;
    }

    public void setProduit(Produit produit) {
        this.produit = produit;
    }   
    public int getNbProdPan() {
        return this.nbProdPan;
    }

    public void setNbProdPan(int nbProdPan) {
        this.nbProdPan = nbProdPan;
    }

}

Commande.java

package model;

import java.io.Serializable;

import javax.persistence.*;

/**
 * Entity implementation class for Entity: Commande
 *
 */
@Entity
@Table(name="COMMANDE")

public class Commande implements Serializable {


    @Id
    @GeneratedValue
    private int id;
    private int modLivrCom;
    private static final long serialVersionUID = 1L;

    @OneToOne(cascade = CascadeType.ALL)
    @JoinColumn(name="idPan")
    private Panier panier;

    @ManyToOne(cascade = CascadeType.ALL)
    @JoinColumn(name="idUtil")
    private Utilisateur utilisateur;

    @ManyToOne(fetch=FetchType.EAGER)
    @JoinColumn(name="idAdr")
    private Adresse adresse;

    @ManyToOne(fetch=FetchType.EAGER)
    @JoinColumn(name="idEtat")
    private Etatcmd etatcmd;

    public Commande() {
        super();
    }   
    public int getId() {
        return this.id;
    }

    public void setId(int id) {
        this.id = id;
    }   
    public int getModLivrCom() {
        return this.modLivrCom;
    }

    public void setModLivrCom(int modLivrCom) {
        this.modLivrCom = modLivrCom;
    }
    public Panier getPanier() {
        return panier;
    }
    public void setPanier(Panier panier) {
        this.panier = panier;
    }
    public Utilisateur getUtilisateur() {
        return utilisateur;
    }
    public void setUtilisateur(Utilisateur utilisateur) {
        this.utilisateur = utilisateur;
    }
    public Adresse getAdresse() {
        return adresse;
    }
    public void setAdresse(Adresse adresse) {
        this.adresse = adresse;
    }
    public Etatcmd getEtatcmd() {
        return etatcmd;
    }
    public void setEtatcmd(Etatcmd etatcmd) {
        this.etatcmd = etatcmd;
    }
}

Panier.java :

package model;

import java.io.Serializable;
import java.util.List;

import javax.persistence.*;

/**
 * Entity implementation class for Entity: Panier
 *
 */
@Entity
@Table(name="PANIER")

public class Panier implements Serializable {


    @Id
    @GeneratedValue
    private int id;
    private float prixTotPan;
    private static final long serialVersionUID = 1L;

    @OneToOne(mappedBy="panier")
    private Commande commande;

    @OneToMany(mappedBy="panier")
    private List<Composer> composers;

    public Panier() {
        super();
    }   
    public int getId() {
        return this.id;
    }

    public void setId(int id) {
        this.id = id;
    }   
    public float getPrixTotPan() {
        return this.prixTotPan;
    }

    public void setPrixTotPan(float prixTotPan) {
        this.prixTotPan = prixTotPan;
    }
    public List<Composer> getComposers() {
        return composers;
    }
    public void setComposers(List<Composer> composers) {
        this.composers = composers;
    }

}

buy.java

Commande laCommande = new Commande();
        if(Integer.parseInt(request.getParameter("idCommande"))==-1){
            Utilisateur utilisateur = UtilisateurDao.find(((Utilisateur)request.getSession().getAttribute("user")).getId());
            laCommande.setAdresse(utilisateur.getAdresse());
        }
        else{
            Enseigne enseigne = EnseigneDao.find(Integer.parseInt(request.getParameter("idLivraison")));
            laCommande.setAdresse(enseigne.getAdresse());
        }
        model.Panier panier = (model.Panier)request.getSession().getAttribute("Panier");
        PanierDao.update(panier);
        Etatcmd etatcmd = EtatcmdDao.find(0);
        laCommande.setEtatcmd(etatcmd);
        laCommande.setModLivrCom(Integer.parseInt(request.getParameter("idCommande")));
        laCommande.setPanier(panier);
        laCommande.setUtilisateur((Utilisateur)request.getSession().getAttribute("user"));
        CommandeDao.create(laCommande);
        RequestDispatcher dispatcher = request.getRequestDispatcher("/jsp/confirmation.jsp");
        dispatcher.forward(request, response);

When I try to execute this code, no object is persisted, and I obtain this error page :

HTTP Status 500 - Unable to find model.Composer with id model.ComposerId@0

type Exception report

message Unable to find model.Composer with id model.ComposerId@0

description The server encountered an internal error that prevented it from fulfilling this request.

exception

javax.persistence.EntityNotFoundException: Unable to find model.Composer with id model.ComposerId@0
    org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl$JpaEntityNotFoundDelegate.handleEntityNotFound(EntityManagerFactoryBuilderImpl.java:183)
    org.hibernate.event.internal.DefaultLoadEventListener.load(DefaultLoadEventListener.java:219)
    org.hibernate.event.internal.DefaultLoadEventListener.proxyOrLoad(DefaultLoadEventListener.java:275)
    org.hibernate.event.internal.DefaultLoadEventListener.onLoad(DefaultLoadEventListener.java:151)
    org.hibernate.internal.SessionImpl.fireLoad(SessionImpl.java:1070)
    org.hibernate.internal.SessionImpl.internalLoad(SessionImpl.java:989)
    org.hibernate.type.EntityType.resolveIdentifier(EntityType.java:716)
    org.hibernate.type.EntityType.resolve(EntityType.java:502)
    org.hibernate.type.EntityType.replace(EntityType.java:366)
    org.hibernate.type.CollectionType.replaceElements(CollectionType.java:549)
    org.hibernate.type.CollectionType.replace(CollectionType.java:690)
    org.hibernate.type.AbstractType.replace(AbstractType.java:178)
    org.hibernate.type.TypeHelper.replaceAssociations(TypeHelper.java:261)
    org.hibernate.event.internal.DefaultMergeEventListener.copyValues(DefaultMergeEventListener.java:433)
    org.hibernate.event.internal.DefaultMergeEventListener.entityIsTransient(DefaultMergeEventListener.java:256)
    org.hibernate.event.internal.DefaultMergeEventListener.onMerge(DefaultMergeEventListener.java:189)
    org.hibernate.event.internal.DefaultMergeEventListener.onMerge(DefaultMergeEventListener.java:85)
    org.hibernate.internal.SessionImpl.fireMerge(SessionImpl.java:876)
    org.hibernate.internal.SessionImpl.merge(SessionImpl.java:858)
    org.hibernate.internal.SessionImpl.merge(SessionImpl.java:863)
    org.hibernate.jpa.spi.AbstractEntityManagerImpl.merge(AbstractEntityManagerImpl.java:1196)
    dao.PanierDao.update(PanierDao.java:44)
    front.Buy.doPost(Buy.java:60)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:646)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:727)

What can I do ?

Thanks for you help

Aucun commentaire:

Enregistrer un commentaire