1. #1
    Nouveau Membre du Club
    Profil pro
    Développeur Web
    Inscrit en
    novembre 2009
    Messages
    61
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : novembre 2009
    Messages : 61
    Points : 29
    Points
    29

    Par défaut [NHibernate] Isoler un objet pour sa suppression

    Bonjour à tous,

    Je sais que la question que je vais poser à déjà été abordée mais de mon côté cela ne fonctionne pas.

    Voici l'erreur:
    deleted object would be re-saved by cascade (remove deleted object from associations)
    Fichier de mapping(simplifié):
    Artwork:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    HasMany(x => x.Comments).Cascade.AllDeleteOrphan().Inverse();
    HasMany(x => x.Promotions).Cascade.AllDeleteOrphan().Inverse();
    HasMany(x => x.Images).Cascade.AllDeleteOrphan().Inverse();
    Comments:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    References(x => x.Artwork).Cascade.None().Not.Nullable();
    Promotions:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    References(x => x.Artwork).Cascade.None().Not.Nullable();
    Images:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    References(x => x.Artwork).Cascade.None().Not.Nullable();
    lorsque je veux supprimer un artwork, j'isole bien l'objet?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    artwork.Comments.Clear();
    artwork.Promotions.Clear();
    artwork.Images.Clear();
     
    bool isDeleted = artworkDao.delete(artwork);-->False

  2. #2
    Membre expérimenté Avatar de NicoL__
    Homme Profil pro
    Inscrit en
    janvier 2011
    Messages
    399
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : janvier 2011
    Messages : 399
    Points : 576
    Points
    576

    Par défaut

    Tu as une exception dans ton DAO ? Si tu as récupérer False c'est qu'un exception a du se produire et qu'elle est catchée.

  3. #3
    Nouveau Membre du Club
    Profil pro
    Développeur Web
    Inscrit en
    novembre 2009
    Messages
    61
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : novembre 2009
    Messages : 61
    Points : 29
    Points
    29

    Par défaut

    l'exception que je récupère dans le catch:
    ObjectDeletedException : deleted object would be re-saved by cascade (remove deleted object from associations)

  4. #4
    Expert Confirmé Avatar de iberserk
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    novembre 2004
    Messages
    1 687
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : novembre 2004
    Messages : 1 687
    Points : 2 896
    Points
    2 896

    Par défaut

    Bonjour, je ne connais pas parfaitement NHIBERNATE mais pourquoi faites vous des clear() sur vos objets enfants?

    Ne vont'il pas être automatiquement supprimé en cascade lors de la suppression de atwork?
    Prendre conscience, c'est transformer le voile qui recouvre la lumière en miroir.
    MCTS Database Development
    MCTS Database Administration

  5. #5
    Membre expérimenté Avatar de NicoL__
    Homme Profil pro
    Inscrit en
    janvier 2011
    Messages
    399
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : janvier 2011
    Messages : 399
    Points : 576
    Points
    576

    Par défaut

    Effectivement dans le delete nhibernate doit identifié que l'objet artwork a été modifié alors qu'il est demandé de l'effacer ce qui engendre l'erreur. Effacer directement sans réaliser les Clear devrait fonctionner.

  6. #6
    Membre Expert
    Inscrit en
    février 2005
    Messages
    1 268
    Détails du profil
    Informations forums :
    Inscription : février 2005
    Messages : 1 268
    Points : 1 926
    Points
    1 926

    Par défaut

    Il suffit de deleter l'artwork. Là tes associations sont assez bizarres...

    C'est le syndrôme de mapper le parent dans les éléments de la collection.

    Tel que ton mapping fluent est fait; si tu delete artwork il deletera toutes les références liées.

    Là comme artwork est deleté et que chaque élément de la collection doit supprimer les orphelins et les liaisons, quand il supprime les enfants et que le parent est supprimé, il tombe sur la contrainte non null, donc il dit qu'il est nécessaire de créer le parent pour pouvoir faire ton delete.

    C'est un mauvais usage.

    Il te suffit de regarder le SQL généré pour comprendre.

  7. #7
    Nouveau Membre du Club
    Profil pro
    Développeur Web
    Inscrit en
    novembre 2009
    Messages
    61
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : novembre 2009
    Messages : 61
    Points : 29
    Points
    29

    Par défaut

    Merci pour les réponses, je vais vérifier le mapping mais c'est quand même bizarre parce que les autre fichiers mappé fonctionne comme celui la et j'ai pas de problème

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

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