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

Persistance des données Java Discussion :

Probleme cascade Delete-Orphan


Sujet :

Persistance des données Java

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2009
    Messages
    230
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 230
    Points : 104
    Points
    104
    Par défaut Probleme cascade Delete-Orphan
    Bonjour,

    Je débute avec Hibernate et je n'arrive pas bien saisir la notation Delete-Orphan au niveau des cascades. J'ai lu la doc hibernate et l'exemple Père/Fils (chapitre 21) mais qd il dise
    Parent p = (Parent) session.load(Parent.class, pid);
    Child c = (Child) p.getChildren().iterator().next();
    p.getChildren().remove(c);
    session.delete(c);
    session.flush();
    Ici le child est vraimant effacé: donc OK compris !
    Dans notre cas, un Child ne peut pas vraiment exister sans son père. Si nous effacons un Child de la collection,
    nous voulons vraiment qu'il soit effacé. Pour cela, nous devons utiliser cascade="all-delete-orphan".
    <set name="children" inverse="true" cascade="all-delete-orphan">
    <key column="parent_id"/>
    <one-to-many class="Child"/>
    </set>
    je ne comprends pas ce qu'apporte cette solution qd on met delete-orphan en plus...

    il y a un truc qui m'échappe.. je dois me mélanger les pinceaux !!

    Si vous pouviez m'éclaircir les idées...
    merci

  2. #2
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2006
    Messages
    3 274
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 3 274
    Points : 4 141
    Points
    4 141
    Par défaut
    Si tu supprimes le père, les enfants seront donc orphelins.
    L'annotation permet de supprimer ses orphelins au moment de la suppression du père.
    C'est plus clair ?

  3. #3
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Septembre 2006
    Messages
    2 937
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2006
    Messages : 2 937
    Points : 4 358
    Points
    4 358
    Par défaut
    Citation Envoyé par fr1man Voir le message
    Si tu supprimes le père, les enfants seront donc orphelins.
    L'annotation permet de supprimer ses orphelins au moment de la suppression du père.
    C'est plus clair ?
    Sauf que çà c'est la fonction du cascade delete pas du cascade delete-orphan…

    Le delete orphan sert à éviter que des enfants enlevés de la Collection<Child> du parent qui a a été chargée par Hibernate ne restent en base même s'ils n'ont pas été effacés explicitement par des opérations de delete/remove dans la session/l'entity manager.
    Dans le cas particulier de @OneToMany avec table intermédiaire, cela permet aussi de nettoyer les records de jointure.

    La doc Hibernate est ambigüe car une fois le delete-orphan spécifié il n'est plus nécessaire de faire "session.delete(c)" : "p.getChildren().remove(c);" suffit.

    (l'exemple ici est plus clair)

    Pour que delete orphan fonctionne correctement, il faut toujours manipuler la Collection chargée par Hibernate (proxified) et ne jamais plus faire de setChildren() explicite pour remplacer une Collection<Child> chargée par Hibernate par une Collection<Child> nouvellement créé dans le code Java. Comme on écrit parfois du code "universel" sans trop se préoccuper d'où vient l'entité Parent, on peut vite avoir des (mauvaises) surprises…

  4. #4
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2009
    Messages
    230
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 230
    Points : 104
    Points
    104
    Par défaut
    Relation One-to-Many : cascade="delete" au niveau du père : tu effaces le père tous les fils sont supprimés : ok !

    Relation One-to-Many : cascade="delete-orphan" (merci pour le lien !)
    Tu n'es pas obligé d’appeler session.delete(child) sur tous les fils que tu veux supprimées de la liste.
    La méthode Remove casse le lien entre Père/Fils, la clé étrangère dans la table fils est à NULL et comme il y a une relation transitive delete-orphan, le fils est alors supprimé.

    Je suis d'accord avec toi, la doc d'hibernate n'est pas tjrs tres claire : y-a-t'il un livre qui explique bcp mieux les principes d'hibernate? le best seller d'hibernate...

    Une autre question : ma relation est en fait Agence/Conseiller.
    Est-ce qu'il y a une tactique pour éliminer automatiquement une agence qui ne contiendrait plus de conseiller ?(règle métier : une agence existe si et seulement si elle possède un conseiller)
    Actuellement, je fais cela manuellement, mais afin d'optimiser le nombre de requëte, je souhaiterais qd je fais un remove sur le conseiller et qu'hibernate s'apperçoive que la liste est maintenant vide, hibernate supprime l'agence.... j'en demande un peu trop peut-être
    j'espère être clair..

    merci pour vos conseils

Discussions similaires

  1. Probleme ON DELETE CASCADE
    Par piero53 dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 08/11/2009, 11h19
  2. probleme requete DELETE
    Par Ice-tea dans le forum Bases de données
    Réponses: 3
    Dernier message: 09/06/2006, 13h47
  3. [ EJB ] [JBoss ] [ XDoclet ] probleme avec cascade-delete
    Par Houbbba dans le forum Wildfly/JBoss
    Réponses: 4
    Dernier message: 03/05/2006, 10h05
  4. probleme de delete dans un destructeur
    Par Chewbi dans le forum C++
    Réponses: 6
    Dernier message: 12/03/2006, 00h29
  5. [EJB2.1 Entity] [XDOCLET]Cascade delete
    Par SEMPERE Benjamin dans le forum Java EE
    Réponses: 3
    Dernier message: 23/02/2005, 09h29

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