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 :

many to many avec attribut autre que les deux clés primaires


Sujet :

Hibernate Java

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Mars 2007
    Messages : 2
    Points : 2
    Points
    2
    Par défaut many to many avec attribut autre que les deux clés primaires
    Bjr ,
    Je suis une débutante en hibernate et spring donc voilà:
    j'ai 3 tables : employe, banque et employe_banque(qui a comme attributs les deux clés primaires ainsi qu'un numéro de compte). Il y a une relation many-to-many bidirectionnelle entre la banque et l'employé.
    mon problèmec'est:
    1. Comment dois-je faire pour insérer le numéro de compte dans la table employe_banque étant donné que pour les deux clés primaires des deux autres tables, c'est hibernate qui s'en charge,
    ou sinon, où est-ce que je dois mette le numéro de compte?

    j'ai déjà essayé de faire cette insertion mais seul les deux clés figurent dans la table employe_banque mais le numéro de compte n'y est pas

    Merci d'avance!
    C'est très urgent donc aidez-moi svp

  2. #2
    Membre habitué Avatar de xv-mnt
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    142
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Juillet 2005
    Messages : 142
    Points : 178
    Points
    178
    Par défaut
    Il faut faire 3 classes (1 par table) et 2 liens manyToOne :
    employe_banque -> employé
    employe_banque -> banque
    La classe qui mappe employe_banque contient les 2 FK et le numéro de compte.

  3. #3
    Modérateur
    Avatar de OButterlin
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    7 313
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 7 313
    Points : 9 529
    Points
    9 529
    Billets dans le blog
    1
    Par défaut
    A priori, tu devrais avoir un mapping de employe vers employe_banque et un mapping de banque vers employe_banque pour l'inverse.
    Quelque chose dans ce genre (pour employe):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
     
    <hibernate-mapping>
        <class name="hibernate.objects.Employe" table="employe">
    ...
        <set name="employe_banque" cascade="save-update" inverse="true">
                <key>
                    <column name="id_employe" not-null="true">
                    </column>
                </key>
                <one-to-many class="hibernate.objects.EmployeBanque" />
            </set>
    ...
    </hibernate-mapping>
     
     
    <hibernate-mapping>
        <class name="hibernate.objects.EmployeBanque" table="employe_banque">
            <composite-id name="id" class="hibernate.objects.EmployeBanqueId">
                <key-property name="idEmploye" type="int">
                    <column name="id_employe" />
                </key-property>
                <key-property name="idBanque" type="int">
                    <column name="id_banque" />
                </key-property>
            </composite-id>
            <many-to-one name="Employe" class="hibernate.objects.Employe" update="false" insert="false" fetch="select">
                <column name="id_employe" not-null="true">
                </column>
            </many-to-one>
            <many-to-one name="Banque" class="hibernate.objects.Banque" update="false" insert="false" fetch="select">
                <column name="id_banque" not-null="true">
                </column>
            </many-to-one>
        </class>
    </hibernate-mapping>
    Ou alors, dans ton application, tu passes par des pojo sur employe_banque et via session.save(pojo) ou session.update(pojo) tu gères ta relation

    A+

  4. #4
    Candidat au Club
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Mars 2007
    Messages : 2
    Points : 2
    Points
    2
    Par défaut
    Merci à OButterlin, j'ai résolu le pb en suivant tes conseils

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

Discussions similaires

  1. Réponses: 5
    Dernier message: 10/08/2014, 17h25
  2. C/S autre que les leaders?
    Par fredtheman dans le forum Bases de données
    Réponses: 13
    Dernier message: 19/05/2009, 12h45
  3. Réponses: 1
    Dernier message: 31/10/2008, 09h50
  4. [SQL] Comment faire avec SQL pour que les visiteurs voient la même donnée
    Par syl2042 dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 28/08/2007, 14h39
  5. Réponses: 2
    Dernier message: 05/02/2007, 09h12

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