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 :

Association porteuse d'information


Sujet :

Hibernate Java

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    122
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juin 2006
    Messages : 122
    Points : 57
    Points
    57
    Par défaut Association porteuse d'information
    Bonjour,

    J'ai une relation many-to-many que j'ai mappé avec succès à l'aide d'hibernate. Cependant, cette association porte une information et je ne sais pas comment l'indiquer dans mon mapping afin de pouvoir la manipuler.

    Voici mon les entités en question:
    Event (event_id, name, start, end)
    User (user_id, login)
    association(event_id, user_id, is_admin)

    Pouvez-vous m'orienter vers des sites/docs ou m'expliquez comment y arriver ?

    Merci

  2. #2
    Membre du Club
    Inscrit en
    Août 2009
    Messages
    41
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 41
    Points : 47
    Points
    47
    Par défaut
    Le manyToMany en hibernate c'est pas la panacé, d'autant plus si tu veux gérer la table de jointure.

    A priori, il est recommandé de plutôt utilisé des relations OneToMany/ManyToOne vers la table de jointure. Un exemple concret ici :
    http://en.wikibooks.org/wiki/Java_Pe...tional_Columns

    En ManyToMany directement avec du JPA/Hibernate je n'ai pas réussi à le faire.

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    122
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juin 2006
    Messages : 122
    Points : 57
    Points
    57
    Par défaut
    Merci pour le lien. Je comprend bien ce qui est expliqué mais je suis assez surpris : Hibernate gère énormément de spécificités mais pas les relations porteuses d'informations ???

    Edit:
    A vue de nez, si je veux récupérer les users associés à un event, ça donnera du côté de Java :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    //EventUser est le bean qui représente la table de jointure entre Event et User
    for (EventUser eu : event1.getAllEventUser()) {
      eu.getUser();
    }
    Soit N requêtes + 1 (N étant le nombre d'user associé à l'event) pour un event au lieu d'une seule jointure... Soit j'ai râté quelque chose chose, soit c'est une mauvaise solution !

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

    Informations forums :
    Inscription : Septembre 2006
    Messages : 2 960
    Points : 4 389
    Points
    4 389
    Par défaut
    Citation Envoyé par gobgob Voir le message
    Merci pour le lien. Je comprend bien ce qui est expliqué mais je suis assez surpris : Hibernate gère énormément de spécificités mais pas les relations porteuses d'informations ???
    regardez le ManyToMany comme une abréviation (comme une "macro") pour vous simplifiez la vie mais techniquement c'est exactement la même chose que faire 2 OneToMany…

    simplement quand on veut une intersection avec des informations, la méthode simplifiée en utilisant la "macro" ManyToMany n'est pas disponible…

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    122
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juin 2006
    Messages : 122
    Points : 57
    Points
    57
    Par défaut
    Effectivement, un many-to-many correspond à 2 one-to-many avec une table intermédiaire.

    Cependant, au niveau du mapping, il serait bon d'avoir un moyen d'obtenir un chaque bout de l'association par une jointure plutôt qu'en faisant une boucle en java pour y parvenir (au coût d'un nombre important de petites requêtes).

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

    Informations forums :
    Inscription : Septembre 2006
    Messages : 2 960
    Points : 4 389
    Points
    4 389
    Par défaut
    Citation Envoyé par gobgob Voir le message
    Effectivement, un many-to-many correspond à 2 one-to-many avec une table intermédiaire.

    Cependant, au niveau du mapping, il serait bon d'avoir un moyen d'obtenir un chaque bout de l'association par une jointure plutôt qu'en faisant une boucle en java pour y parvenir (au coût d'un nombre important de petites requêtes).
    mais dès que la table de jointure est une entité à part entière, le query doit résoudre (au moins) 2 entités à chaque fetch…

    c'est là que ça se complique… car dès qu'on ouvre cette possibilité il faut que le générateur de query fonctionne pour tous les cas possibles… pas seulement votre situation simple…

    l'optimisation par celui qui conçoit le schéma sera toujours meilleure…

  7. #7
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    122
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juin 2006
    Messages : 122
    Points : 57
    Points
    57
    Par défaut
    Je n'ai pas très bien compris la dernière réponse...

    J'ai tout de même eu vent d'une solution potentielle mais partielle. Dans la doc hibernate, on trouve la solution à la rubrique :
    doc-hibernate-officielle

    Elle a au moins une faiblesse, la relation ne peut être bidirectionnelle. Comme toujours avec Hibernate, on est complètement livré à soi même, la doc nous fait de bien belles explications sur ce qui est possible/impossible/obligatoire/facultatif mais pas sur la façon de le faire (des exemples ! des exemples ! et des exemples complets enfin ! ). Là je me sens totalement largué...

Discussions similaires

  1. Mapper une association porteuse d'information
    Par cereal dans le forum Hibernate
    Réponses: 1
    Dernier message: 11/08/2009, 14h03
  2. [MCD] Association 0,1 -- 0,n porteuse d'informations
    Par CinePhil dans le forum Schéma
    Réponses: 5
    Dernier message: 26/03/2008, 00h56
  3. Réponses: 1
    Dernier message: 06/07/2007, 11h07
  4. Association porteuse
    Par Fabouney dans le forum SQL Procédural
    Réponses: 2
    Dernier message: 12/10/2005, 15h50
  5. [Renseignement] Association porteuse de données
    Par Machjaghjolu dans le forum Langage SQL
    Réponses: 5
    Dernier message: 01/06/2005, 14h16

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