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 :

set, many-to-many : problème suppression


Sujet :

Hibernate Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre expérimenté

    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2008
    Messages
    85
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Loire Atlantique (Pays de la Loire)

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

    Informations forums :
    Inscription : Avril 2008
    Messages : 85
    Par défaut set, many-to-many : problème suppression
    Bonjour, avant tout voilà un petit résumé de mon mapping:

    j'ai les tables suivantes

    PARAM_SEMAINES : id_param_semaine, libelle
    TRANCHES_HORAIRES : id_param_th, libelle, heure_debut, heure_fin, pas
    PARAM_SEMAINES_TRANCHES_HORAIRES : id_param_semaine, id_param_th

    Un PARAM_SEMAINE peut être composé de plusieurs PARAM_TRANCHES_HORAIRES,
    et un PARAM_TRANCHE_HORAIRE peut appartenir à différents PARAM_SEMAINE

    Mon mapping est le suivant:

    => ParamSemaineDAO.hbm.xml :

    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
     
    <hibernate-mapping package="com.catamania.mygwt.explorer.server.domain">
    	<class
    		name="ParamSemaineDAO"
    		table="param_semaines">
     
    		<id
    			name="id"
    			column="id_param_semaine">
    			<generator class="increment"/>
    		</id>
     
    		<property
    			name="libelle"
    			column="libelle"
    			not-null="true"/>	
     
     
        <set name="paramTranchesHoraires" table="param_semaines_tranches_horaires" cascade="save-update">
            <key column="id_param_semaine"/>
            <many-to-many column="id_param_th" class="ParamTrancheHoraireDAO" order-by="heure_debut asc"/>
        </set>
     
     
    	</class>	
    </hibernate-mapping>
    => ParamTrancheHoraireDAO.hbm.xml

    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
     
    <hibernate-mapping package="com.catamania.mygwt.explorer.server.domain">
    	<class
    		name="ParamTrancheHoraireDAO"
    		table="param_tranches_horaires">
     
    		<id
    			name="id"
    			column="id_param_th">
    			<generator class="increment"/>
    		</id>
     
    		<property
    			name="libelle"
    			column="libelle"
    			not-null="true"/>	
     
    		<property
    			name="heureDeb"
    			column="heure_debut"
    			not-null="true"/>
     
    		<property
    			name="heureFin"
    			column="heure_fin"
    			not-null="true"/>	
     
    		<property
    			name="pas"
    			column="pas"
    			not-null="true"/>
     
    	</class>	
    </hibernate-mapping>
    L'ajout des PARAM_TRANCHE_HORAIRES et des PARAM_SEMAINE ne me posent pas de problème.

    Le soucis vient de la suppression d'un PARAM_SEMAINE. En effet, la suppression se fait bien dans la table
    PARAM_SEMAINES, mais je ne parviens pas à faire en sorte que la/les ligne(s) correspondante(s) soi(en)t supprimée(s)
    dans la table de jointure PARAM_SEMAINES_TRANCHES_HORAIRES.

    Existe-il une astuce au niveau du mapping pour palier à ce problème?

    Merci d'avance

  2. #2
    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
    Billets dans le blog
    1
    Par défaut
    C'est normal, tu as limité les traitements cascade à "save-update"
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    <set name="paramTranchesHoraires" table="param_semaines_tranches_horaires" cascade="save-update">
       <key column="id_param_semaine"/>        
       <many-to-many column="id_param_th" class="ParamTrancheHoraireDAO" order-by="heure_debut asc"/>
    </set>
    A+
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  3. #3
    Membre expérimenté

    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2008
    Messages
    85
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Loire Atlantique (Pays de la Loire)

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

    Informations forums :
    Inscription : Avril 2008
    Messages : 85
    Par défaut
    Ok, j'ai bien essayé de mettre mais rien n'y fait, mon problème persiste...

Discussions similaires

  1. many-to-many problème de persistance
    Par kokumbo dans le forum Hibernate
    Réponses: 1
    Dernier message: 28/11/2007, 16h11
  2. [Hibernate] Join fetch et set (one-to-many)
    Par TiMiD dans le forum Hibernate
    Réponses: 2
    Dernier message: 26/10/2007, 02h48
  3. Un peu de mal a comprendre le concepte "one-to-many" et "many-to-many"
    Par chriscoolletoubibe dans le forum Hibernate
    Réponses: 4
    Dernier message: 29/03/2007, 18h50
  4. Hibernate: many-to-many, collections SET vides
    Par tzikin dans le forum Hibernate
    Réponses: 1
    Dernier message: 20/02/2007, 12h24
  5. Réponses: 1
    Dernier message: 03/12/2006, 20h56

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