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.
|