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

Entity Framework Discussion :

Entity Framework suppresion d'une relation many to many


Sujet :

Entity Framework

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Juillet 2010
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2010
    Messages : 16
    Points : 13
    Points
    13
    Par défaut Entity Framework suppresion d'une relation many to many
    Bonjour,

    Je suis en train d'implémenter un projet en utilisant Entity Framework 6 avec FluentAPI, et j'ai un problème avec la suppression des relation de type Many To Many.
    En effet dans ce genre de relation au niveau de la BDD j'ai besoin d'une table de lien qui référence les deux tables entre lesquelles je doit créer ma relation. Or pour des raisons internes nos table de liens ont un format particulier :
    Elle contiennent 4 champs :
    - IdTable1 (Foreigne key vers Table1)
    - IdTable2 (Foreign key vers Table2)
    - DateDebut (DateTime indiquant le début de validité du lien)
    - DateFin (DateTime indiquant la fin de validité du lien)

    Dans le cas d'une suppression du lien entre deux objets l'enregistrement dans la table de lien ne doit pas être supprimé, mais mis à jour en remplissant le champ "DateFin".
    Y a t il un moyen simple de faire ceci en utilisant Entity FrameWork? En quelque sorte je suis modifier la commande SQL qui sera utilisé lorsque l'on veut supprimer un lien entre deux objets ou quelque chose comme ça...

    Corolairement à ça lorsque Entity me ramène la collection des objets de type T1 liés à un objet de type T2, comment puis lui préciser de ne pas prendre en compte les enregistrements de la table de lien qui ont une date de fin non NULL?

    L'un de vous aurait il une solution à mon problème?

    Merci.
    Cordialement,
    Vince

  2. #2
    Membre habitué
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Novembre 2010
    Messages
    185
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haut Rhin (Alsace)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Conseil

    Informations forums :
    Inscription : Novembre 2010
    Messages : 185
    Points : 167
    Points
    167
    Par défaut
    Salut,
    C'est peut-être un peu tard mais si tu as 2 dates, tu dois déclarer ton objet pour faire ta table avec ces 2 dates.
    Ensuite, pour mettre à jour la date, tu surcharges la méthode SaveChanges() dans laquelle tu regardes les objets qui ont été supprimés pour changer leur statut en modifié et ajouter la date de séparation de lien.

    Ca donnerait quelque chose comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
            public override int SaveChanges(){
                // Ajouter le suppresseur et la date de suppression pour les objets Table1Table2Link en suppression
                var deletedEntities = ChangeTracker.Entries()
                                                   .Where(o => o.State == EntityState.Deleted &&
                                                               o.Entity is Table1Table2Link);
     
                // Changer l'état de l'entité en modifié
                deletedEntities.AsParallel().ForAll(o => o.State = EntityState.Modified);
     
                // Ajouter le suppresseur et la date de suppression pour les objets Table1Table2Link en suppression
                deletedEntities.Select(o => o.Entity)
                               .AsParallel()
                               .ForAll(o => (o as Table1Table2Link)?.DeletedDate = now);
    }

Discussions similaires

  1. Réponses: 0
    Dernier message: 12/03/2009, 16h16
  2. problème de jointure dans une relation many to one
    Par info_plus dans le forum JPA
    Réponses: 1
    Dernier message: 25/12/2008, 12h29
  3. Réponses: 3
    Dernier message: 26/02/2007, 10h14
  4. Réponses: 3
    Dernier message: 05/01/2007, 10h44

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