IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Hibernate Java Discussion :

Jointure entre deux entités


Sujet :

Hibernate Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2007
    Messages
    165
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2007
    Messages : 165
    Par défaut Jointure entre deux entités
    Bonsoir,
    Je me confronte à un problème en joignant deux entités dans une requête SQL.

    Entité chez le client :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    @OneToMany(mappedBy = "idClient")
    private List<Reservationbilletavion> idClientCA;
    Entité de réservation de billets
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    @JoinColumn(name = "ID_CLIENT", referencedColumnName = "ID")
    @ManyToOne
    private Client idClient;
    La requête EJBQL :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    public Client getAllReservationById(int idClient) {
     
             try {
             // les des réservations de billets d'avions
             return (Client) em.createQuery("SELECT c " +
                                            "FROM Client c LEFT JOIN c.idClientCA ca " +
                                            "WHERE c.id =:ID"
                                      ).setParameter("ID",  (long) idClient)
                                     .getSingleResult();
              } catch (Throwable th) {
                throw new edtcException(th, 1);
              }
    }
    ça me dit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    org.hibernate.LazyInitializationException: failed to lazily initialize a collection of role no session or session was closed.
    J'espère trouvé une personne puissant m'aider.
    Cordialement.

  2. #2
    Membre confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2007
    Messages
    165
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2007
    Messages : 165
    Par défaut
    La soluce, il en existe trois :

    - Mettre le fetch à EAGER (non conseillé),
    - Changer la gestion de la persistance à EXTENDED,
    - Utiliser la méthode size() pour forcer le getters.

    J'ai utilisé la dernière.

    Ensuite pour le problème de cycle infini j'ai utilise l'annotation XMLTransiant sur le getters d'idClient.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Jointure entre deux entités
    Par verbose dans le forum JPA
    Réponses: 8
    Dernier message: 19/10/2010, 21h55
  2. [MySQL] Jointure entre deux tables
    Par Flushovsky dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 03/10/2005, 18h55
  3. PROBLEME DE JOINTURE ENTRE DEUX TABLE
    Par DarkMax dans le forum Langage SQL
    Réponses: 13
    Dernier message: 13/01/2005, 15h11
  4. Jointure entre deux tables et résultat
    Par Asdorve dans le forum Langage SQL
    Réponses: 2
    Dernier message: 02/06/2004, 14h50
  5. jointure entre deux requete
    Par Youssef dans le forum Langage SQL
    Réponses: 21
    Dernier message: 15/01/2004, 15h13

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo