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 :

requete plusieurs table


Sujet :

Hibernate Java

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Février 2007
    Messages
    382
    Détails du profil
    Informations personnelles :
    Âge : 35
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 382
    Points : 73
    Points
    73
    Par défaut requete plusieurs table
    Bonjour,

    j'aimerais savoir comment faire pour récupérer une requêtes qui à lieux entre plusieurs table :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    select *
    from grade, membre
    where grade.id = membre.id
    Comment faire pour gérer ce genre de requêtes ?

  2. #2
    Futur Membre du Club
    Profil pro
    dev
    Inscrit en
    Avril 2008
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : dev

    Informations forums :
    Inscription : Avril 2008
    Messages : 4
    Points : 5
    Points
    5
    Par défaut
    bonjour,
    tu peux recuperer le resultat sous forme d'une liste d'objet:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    List list= session.createQuery("from grade g,membre m where g.id=m.id'").list();

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Février 2007
    Messages
    382
    Détails du profil
    Informations personnelles :
    Âge : 35
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 382
    Points : 73
    Points
    73
    Par défaut
    Oui mais après comment je fait pour récupérer mes valeurs, je doit faire un cast sur grade, membre... ?

  4. #4
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Septembre 2006
    Messages
    2 953
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2006
    Messages : 2 953
    Points : 4 379
    Points
    4 379
    Par défaut
    Citation Envoyé par damien77 Voir le message
    Oui mais après comment je fait pour récupérer mes valeurs, je doit faire un cast sur grade, membre... ?
    vous auriez une réponse plus adaptée à vos besoins si vous expliquiez quelle est la relation entre grade et membre…

    le fait que vous testiez leurs id respectifs laisse entendre une relation de type "is-a" dans un sens ou l'autre (l'un est sous-classe de l'autre) alors que les noms des classes eux laissent plutôt que vous avez une one-to-many mais alors le test d'égalité des id n'a pas de sens… (on s'attendrait plutôt à voir g.id = m.groupe_id par exemple…)

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Février 2007
    Messages
    382
    Détails du profil
    Informations personnelles :
    Âge : 35
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 382
    Points : 73
    Points
    73
    Par défaut
    un membre à un et un seul grade.
    mais pour un grade nous pouvons avoir plusieurs membre.

  6. #6
    Futur Membre du Club
    Profil pro
    dev
    Inscrit en
    Avril 2008
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : dev

    Informations forums :
    Inscription : Avril 2008
    Messages : 4
    Points : 5
    Points
    5
    Par défaut
    Une fois la liste recupere tu cast ton objet en fonction de si c'est un grade ou un membre puis tu recupere tes valeurs.

  7. #7
    Membre régulier
    Profil pro
    Inscrit en
    Février 2007
    Messages
    382
    Détails du profil
    Informations personnelles :
    Âge : 35
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 382
    Points : 73
    Points
    73
    Par défaut
    D'accord,
    donc il me suffit de faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    List list = session.createQuery("from grade g,membre m where g.id=m.id").list();
    (Membre)list.get(i);
    (Grade)list.get(i);
    Je ne savais pas.

    Merci de l'aide

  8. #8
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Septembre 2006
    Messages
    2 953
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2006
    Messages : 2 953
    Points : 4 379
    Points
    4 379
    Par défaut
    Citation Envoyé par damien77 Voir le message
    un membre à un et un seul grade.
    mais pour un grade nous pouvons avoir plusieurs membre.
    donc une relation one-to-many, alors tester l'égalité des id n'a pas de sens...
    le query renverra toujours un ensemble vide ou au moins un ensemble aléatoire…

    et d'ailleurs vous n'avez pas besoin d'écrire de query pour obtenir les membres d'un groupe si vous faites votre mapping de la relation one-to-many correctement… Hibernate le fera pour vous et remplira correctement la collection des membres dans le groupe…
    (le "Set<Membre> membres" que vous devriez avoir déclaré dans Groupe…)

  9. #9
    Membre régulier
    Profil pro
    Inscrit en
    Février 2007
    Messages
    382
    Détails du profil
    Informations personnelles :
    Âge : 35
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 382
    Points : 73
    Points
    73
    Par défaut
    Oui mais dans ma table membre :
    id c'est un clé étrangère sur id de grade.
    l'identifiant dans ma table membre c'est son pseudo.

    Mais la je voulais afficher :

    pseudoDuMembre à pour grade nomDuGrade...

  10. #10
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Septembre 2006
    Messages
    2 953
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2006
    Messages : 2 953
    Points : 4 379
    Points
    4 379
    Par défaut
    Citation Envoyé par damien77 Voir le message
    Oui mais dans ma table membre :
    id c'est un clé étrangère sur id de grade.
    l'identifiant dans ma table membre c'est son pseudo.

    Mais la je voulais afficher :

    pseudoDuMembre à pour grade nomDuGrade...
    utiliser "id" pour une clé étrangère c'est vraiment chercher les ennnuis…

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    for(Object o : getEntityManager().createQuery("From Membre").getResultList()) {
    Member m =(Member)o ;
    String message = m.getPseudo() + " à pour grade " + m.getGrade().getNom() ;
    …
    }

  11. #11
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Points : 48 807
    Points
    48 807
    Par défaut
    tu fait betement un select sur les membre, puis pour 'afficher' tu fait un "member " + membre.getPseudo() + " a pour grade " + member.getGrade().getName().

    Pas besoin de récupérer les deux sur ta requete

    Edit: toasted

Discussions similaires

  1. Requete plusieurs tables
    Par abdelhadi008 dans le forum Zend_Db
    Réponses: 1
    Dernier message: 25/05/2009, 13h56
  2. [MySQL] requete avec liaisons avec plusieurs tables
    Par pod1978 dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 10/03/2006, 22h21
  3. Réponses: 2
    Dernier message: 09/01/2006, 16h10
  4. requete sur plusieurs tables
    Par manaboko dans le forum Requêtes
    Réponses: 6
    Dernier message: 13/12/2005, 17h07
  5. [Débutant] requete entre plusieurs tables
    Par xufux dans le forum Langage SQL
    Réponses: 2
    Dernier message: 10/08/2005, 14h00

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