These old forums are deprecated now and set to read-only. We are waiting for you on our new forums!
More modern, Discourse-based and with GitHub/Google/Twitter authentication built-in.

All times are UTC - 5 hours [ DST ]



Forum locked This topic is locked, you cannot edit posts or make further replies.  [ 1 post ] 
Author Message
 Post subject: Insertion dans une association avec attribut
PostPosted: Mon Jul 30, 2007 10:45 am 
Newbie

Joined: Mon Jul 30, 2007 10:23 am
Posts: 1
Bonjour,
Je souhaite insérer un objet dans ma base de données qui correspond à une association et j'ai un problème.

Je m'explique :

Je prend un exemple pour simplifier ma question.
J'ai une classe Commande et une classe Composant. J'ai bien réussi à mapper ces 2 classes et à faire des insertions, misa à jour, ...
Maintenant, j'ai créé une classe Contenu qui correspond à l'assocation entre Commande et Composant.
Une commande possède de zéro à plusieurs composants.
Un composant est recensé dans aucune ou plusieurs commandes.
(c'est donc une relation many-to-many si j'ai bien compris).

Si je considère que l'association n'a pas d'attributs en plus que la clé (qui est composé des deux clés étrangères), j'arrive à faire un insert.
Pour cela, dans Commande, j'ai créé une liste de Composant et pour ajouter un composant j'ajoute un Composant dans cette liste puis j'applique la méthode update() à l'objet Commande.
1ère question : est-ce la bonne méthode ?

Or, je souhaite aussi gérer une quantité de chaque composant. Donc l'objet Contenu reçoit en plus un attribut quantité.

Si j'essaye de créer directement un objet de type Contenu, à lui appliquer les méthodes set pour définir la valeur de ses attributs et appliquer la méthode save() (ou saveOrUpdate() ), j'obtient un Exception de type ClassCastException.

Si j'essaye d'utiliser la méthode d'insertion que j'ai cité plus haut (ajout d'un objet dans la liste), j'obtiens l'erreur :
org.hibernate.NonUniqueObjectException: a different object with the same identifier value was already associated with the session [Composant#001]

Mapping de la liste dans Commande.hbm.xml :

<bag name="contenus" table="CONTENU"
cascade="all" lazy="false" >
<key column="IDCOMMANDE"/>
<one-to-many class="Contenu"/>
</bag>


Mapping de la classe d'association :
<hibernate-mapping package="hibernate.bean">
<class name="Contenu" table="CONTENU" >

<composite-id name="id" class="ContenuId">
<key-many-to-one name="commande" class="Commande" column="IDCOMMANDE" lazy="false" />
<key-many-to-one name="composant" class="Composant" column="IDCOMPOSANT" lazy="false" />
</composite-id>

<property name="qte" column="QUANTITE"
type="integer" not-null="true" />
</class>
</hibernate-mapping>

2ième question : est-ce la bonne méthode?

Pouvez vous m'indiquer quelle est la façon de faire habituelle?
S'agit-il d'un problème d'insertion en cascade ?

Je vous remercie d'avance.


Top
 Profile  
 
Display posts from previous:  Sort by  
Forum locked This topic is locked, you cannot edit posts or make further replies.  [ 1 post ] 

All times are UTC - 5 hours [ DST ]


You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum

Search for:
© Copyright 2014, Red Hat Inc. All rights reserved. JBoss and Hibernate are registered trademarks and servicemarks of Red Hat, Inc.