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 :

Problème de conception - mapping d'une table d'association avec trois champs


Sujet :

Hibernate Java

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 5
    Points : 5
    Points
    5
    Par défaut Problème de conception - mapping d'une table d'association avec trois champs
    Bonjour,

    Je suis en train de découvrir Hibernate et je me heurte à un problème de conception, j'aurais besoin de votre avis.

    Voici la situation.

    J'ai une classe Member et une classe Event. Un Event possède plusieurs Member et vice versa. Au niveau de ma base de donnée, j'ai donc une table d'association entre Member et Event.

    Un Member peut avoir un type différent (PROPRIO, GUEST, ...) en fonction de l'Event.


    Je n'ai pas de soucis pour mapper la relation n:m entre Event et Member avec Hibernate, mon problème se situe au niveau du Type. Je ne vois pas bien comment intégrer cette notion

    J'ai pensé à utiliser une Map avec pour clé un Member et comme valeur son type, mais je n'arrive pas bien à voir où placer le champ Type. Sur la table d'association ? Mais je ne vois pas comment le mapper avec hibernate ...

    Voilà, si quelqu'un à une idée, elle sera la bienvenue.
    Merci d'avance.

    Vincent

  2. #2
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    129
    Détails du profil
    Informations personnelles :
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Juillet 2007
    Messages : 129
    Points : 109
    Points
    109
    Par défaut
    Je suis confronté au même souci. Merci de nous éclairer la dessus

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 5
    Points : 5
    Points
    5
    Par défaut
    J'ai finalement trouvé une solution qui a l'air de fonctionner.

    J'ai donc une table d'association avec 3 champs (id_member, id_event, type_member)

    Dans ma ma classe Member j'ai une HashMap<Event, typeMember>.

    Le mapping hibernate de la classe Member

    Code xml : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    <map name="events" table="event_has_member">
    	<key column="id_member" />
    	<index-many-to-many column="id_event" class="Event" />
    	<element column="type_member" type="string" />
    </map>

    J'espère que ça en aidera certains ...

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 23/12/2010, 16h39
  2. [Conception] Enregistrement d'une table dans un txt avec mise en page
    Par sephirothmana dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 28/06/2006, 13h55
  3. [Conception] insertion, dans une table, de floats
    Par ozzmax dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 04/05/2006, 15h36
  4. Copie d'une table entre bases, avec un champs long
    Par LaVaZza dans le forum Oracle
    Réponses: 6
    Dernier message: 18/04/2006, 16h58
  5. [MySQL] Problème de mise à jour d'une table
    Par SnickeursMan dans le forum PHP & Base de données
    Réponses: 18
    Dernier message: 17/01/2006, 11h39

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