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 lié à une autre entity au choix


Sujet :

Entity Framework

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2011
    Messages
    33
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2011
    Messages : 33
    Par défaut Entity lié à une autre entity au choix
    Bonjour,

    Je suis confronté à un problème de relations entre plusieurs entities. J'ai une entity "Slot" qui est lié à une autre entity mais qui n'est pas toujours du même type, elle peut-être soit un "Center" soit un "Vehicle".

    On a donc les relations suivantes:
    - Slot ---> Center : "One to Many"
    - Slot ---> Vehicle : "One to One" (un véhicule ne peut avoir qu'un seul emplacement)

    Voici comment se présente le code de mon entité :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
        public class Slot
        {
            public int ID { get; set; }
            public string Code { get; set; }
            public int MaximumCapacity { get; set; }
     
            public virtual Center Center { get; set; }
            public virtual Vehicle Vehicle { get; set; }
     
            public virtual List<Package> Packages { get; set; }
        }
    Je pense qu'il ne devrait pas y avoir une propriété pour Center et une autre pour Vehicle, il faudrait pouvoir avoir la même propriété afin de définir à quel type le Slot appartient-il. Comment établir cette relation?

  2. #2
    Membre Expert Avatar de Er3van
    Homme Profil pro
    Architecte Logiciel
    Inscrit en
    Avril 2008
    Messages
    1 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Architecte Logiciel
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2008
    Messages : 1 430
    Par défaut
    Difficile de te répondre quand on ne comprend pas la problématique fonctionnelle.
    Qu'est-ce qu'un slot, un center ? Et quelle est leur interaction avec un véhicule?

    A vue de nez ça à l'air d'un problème de modèle, mais difficile à affirmer...

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    351
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Côte d'Or (Bourgogne)

    Informations forums :
    Inscription : Juin 2006
    Messages : 351
    Par défaut
    Salut,

    Je ne vois que deux solutions pour ma part :
    • Conserver tes deux champs et ajouter une règle métier (comme le ferait un Trigger SQL, sauf que les triggers c'est le mal)
    • Avoir un mécanisme d'IOC (si tu fais du EF Code First) où tu dirais que tes objets Center et Vehicle implémentent une interface ISlot. Du coup tu n'aurais qu'une propriété de façon à obtenir ça
      Code xaml : Sélectionner tout - Visualiser dans une fenêtre à part
      1
      2
       
      public ISlot MonSlot {get;set;}

    Mais dans une expérience précédente je me rappelle avoir eu des soucis au niveau des Interfaces et d'EFCF, mais je ne sais plus si c'était lié à EF lui même ou aux WCF Data Services qui ne générait pas côté client les interfaces (du coup obligé de faire soi même de la meta programmation)

    Néanmois, comme l'a dit Er3van, on ne comprend pas forcément le contexte donc pas évident de t'aider d'avantage.

    Edit : Lorsque j'ai écrit, je ne me rappelais plus de ta contrainte de One To Many d'une part et de One To One d'autre part. A priori je ne vois pas d'autre solution que la première que je t'ai proposé, EF ne permet pas de miracle, ou revoit ta conception

  4. #4
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2011
    Messages
    33
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2011
    Messages : 33
    Par défaut
    Tout d'abord merci pour vos réponses.

    Je vais un peu plus décrire le contexte pour que vous comprenez mieux les besoins de l'utilisateur. L'application est un outil de gestion destiné à une entreprise spécialisé dans le transport de colis, avec plusieurs objets imposés dont:

    - les Package, qui représentent des colis
    - les Slot, qui représentent des volumes comportant plusieurs Package
    - les Center, qui représentent les centres de distribution et ayant plusieurs Slot
    - les Vehicle, qui représentent les véhicules de livraison et n'ayant qu'un seul Slot.

    Voilà donc ma problématique, comment représenter en CodeFirst les relations vers Center et Vehicle à partir de Slot, sachant qu'un Slot ne peut appartenir qu'à un seul type.

Discussions similaires

  1. Slider une div sur une autre div au choix
    Par godjojo dans le forum jQuery
    Réponses: 2
    Dernier message: 15/02/2012, 09h20
  2. Linq to Entity avec une autre Base de Donnée
    Par canacana dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 28/11/2011, 07h45
  3. [XL-2003] liste de choix accedant à une autre liste de choix
    Par deamonRav dans le forum Conception
    Réponses: 0
    Dernier message: 21/06/2010, 16h45
  4. "References an unknown entity" dans une autres jar
    Par crofteur dans le forum Hibernate
    Réponses: 1
    Dernier message: 07/06/2010, 13h12
  5. Réponses: 8
    Dernier message: 26/03/2010, 10h05

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