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 :

Insertion de données avec un mapping one-to-many


Sujet :

Hibernate Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2012
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Juin 2012
    Messages : 6
    Par défaut Insertion de données avec un mapping one-to-many
    Bonjour tout le monde,

    J'ai cherché un peu partout sur Google, mais je n'ai rien trouvé qui puisse m'aider.

    J'essaie de créer un mapping de type one-to-many avec Hibernate. La récupération de données fonctionne très bien, c'est l'insertion de données qui pêche.

    Je m'explique, j'ai une classe Classe1, mappée vers une première table, qui possède un attribut de type Set<Classe2>, mappé vers une deuxième table. Lorsque j'essaie d'insérer des données, tout fonctionne au niveau de la première table, mais rien ne se passe sur la deuxième. Je ne reçoit aucun message d'erreur.
    Voici mon code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    public class Classe1 implements Serializable{
    	private int id;
    	private Set<Classe2> queries=new HashSet<Classe2>(0);
    ...
    Constructeurs
    Getters/Setters 
    }
    Avec le premier fichier de mapping
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    <hibernate-mapping>
     <class name="Classe1" table="AT01">
      <id name="id" type="int" column="AT01_ID">
       <generator class="increment"/>
      </id>
      <set name="queries" table="AT03" inverse="true" lazy="true" >
      	<key not-null="true">
      		<column name="AT03_ID1"/>
      	</key>
      	<one-to-many class="Classe2"/>
      </set>
     </class>
    </hibernate-mapping>
    Ma deuxième classe:
    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
    public class Classe2 implements Serializable{
    	private int id1;
    	private int id2;
    	private String data;
    	public Classe2(int id2, String data) {
    		super();
    		this.id2 = id2;
    		this.data = data;
    	}
    	public Classe2() {
    		super();
    	}
    ...
    Getters/Setters 
    }
    Et le fichier de mapping:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    <hibernate-mapping>
    	<class name="Classe2" table="AT03">
    		<composite-id>
    			<key-many-to-one name="id1" class="Classe1" column="AT03_ID1" />
    			<key-property name="id2" type="int">
    				<column name="AT03_ID2" />
    			</key-property>
    		</composite-id>
    		<property name="data" type="java.lang.String">
    			<column name="AT03_DATA" />
    		</property>
    	</class>
    </hibernate-mapping>
    Pour insérer les données, je procède comme suit:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    		Configuration config = initializeConfiguration();
    		config.addClass(Classe1.class); 
    		config.addClass(Classe2.class);
    		Session session = config.buildSessionFactory().openSession();
     
    		Set<Classe2> monSet= new HashSet<Classe2>(0);
    		monSet.add(new Classe2(1, "toto"));
    		monSet.add(new Classe2(1, "titi"));
    		monSet.add(new Classe2(1, "tata"));
     
    		session.beginTransaction();
    		Classe1 objetPrincipal = new Classe1(monSet);
    		session.save(objetPrincipal);
    		session.getTransaction().commit();
    J'espère que vous pourrez m'aider

  2. #2
    Membre Expert
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2007
    Messages
    2 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Juin 2007
    Messages : 2 938
    Par défaut
    Bonjour,

    Il faudrait que tu tu précises à hibernate de faire un cascade et le type de cascade (REMOVE,UPDATE, ALL pour tout), ce qui donnerait par exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    <hibernate-mapping>
     <class name="Classe1" table="AT01">
      <id name="id" type="int" column="AT01_ID">
       <generator class="increment"/>
      </id>
      <set name="queries" table="AT03" inverse="true" lazy="true" cascade="all">
      	<key not-null="true">
      		<column name="AT03_ID1"/>
      	</key>
      	<one-to-many class="Classe2"/>
      </set>
     </class>

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2012
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Juin 2012
    Messages : 6
    Par défaut
    Merci pour ta réponse. Ça marche nickel maintenant

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

Discussions similaires

  1. Insertion de données avec php5
    Par Ludo75 dans le forum Langage
    Réponses: 3
    Dernier message: 24/08/2010, 15h18
  2. [MySQL] Insertion de données avec apostrophes dans ma base
    Par kawther dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 01/04/2007, 09h06
  3. problème d'insertion de données dans une map
    Par kifouillou dans le forum Collection et Stream
    Réponses: 11
    Dernier message: 21/02/2007, 10h10
  4. Insertion de données avec Posgretsql
    Par djibril dans le forum PostgreSQL
    Réponses: 3
    Dernier message: 18/05/2004, 11h23
  5. Réponses: 2
    Dernier message: 14/05/2004, 14h32

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