Publicité
+ Répondre à la discussion
Affichage des résultats 1 à 7 sur 7
  1. #1
    Nouveau Membre du Club
    Profil pro Nicolas DELFOUR
    Développeur Web
    Inscrit en
    novembre 2009
    Messages
    61
    Détails du profil
    Informations personnelles :
    Nom : Nicolas DELFOUR
    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 :
    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 :
    1
    2
     
    References(x => x.Artwork).Cascade.None().Not.Nullable();
    Promotions:
    Code :
    1
    2
     
    References(x => x.Artwork).Cascade.None().Not.Nullable();
    Images:
    Code :
    1
    2
     
    References(x => x.Artwork).Cascade.None().Not.Nullable();
    lorsque je veux supprimer un artwork, j'isole bien l'objet?
    Code :
    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 Nicolas
    Inscrit en
    janvier 2011
    Messages
    399
    Détails du profil
    Informations personnelles :
    Nom : Homme Nicolas
    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 Nicolas DELFOUR
    Développeur Web
    Inscrit en
    novembre 2009
    Messages
    61
    Détails du profil
    Informations personnelles :
    Nom : Nicolas DELFOUR
    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 Bruno IGNACE
    Architecte de base de données
    Inscrit en
    novembre 2004
    Messages
    1 652
    Détails du profil
    Informations personnelles :
    Nom : Homme Bruno IGNACE
    Âge : 32
    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 652
    Points : 2 833
    Points
    2 833

    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 Nicolas
    Inscrit en
    janvier 2011
    Messages
    399
    Détails du profil
    Informations personnelles :
    Nom : Homme Nicolas
    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
    mars 2005
    Messages
    1 249
    Détails du profil
    Informations forums :
    Inscription : mars 2005
    Messages : 1 249
    Points : 1 884
    Points
    1 884

    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 Nicolas DELFOUR
    Développeur Web
    Inscrit en
    novembre 2009
    Messages
    61
    Détails du profil
    Informations personnelles :
    Nom : Nicolas DELFOUR
    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.

Liens sociaux

Règles de messages

  • Vous ne pouvez pas créer de nouvelles discussions
  • Vous ne pouvez pas envoyer des réponses
  • Vous ne pouvez pas envoyer des pièces jointes
  • Vous ne pouvez pas modifier vos messages
  •