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

ASP.NET Discussion :

Entity Framework 6 - relations entre les entités impossible a déterminer


Sujet :

ASP.NET

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Février 2006
    Messages
    136
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 136
    Points : 65
    Points
    65
    Par défaut Entity Framework 6 - relations entre les entités impossible a déterminer
    Bonjour collègues,

    Je travail sur la migration d'un ancien portail ASP vers un version ASP.Net (MVC5 et EF6). Ce portail repose sur une base SQL Server très mal conçue. Aucune relation, les champs servant de clés étrangère ont des nom plutôt foireux...enfin du coup je suis partie sur un Développement en CodeFirst (je précise aussi que c'est mon premier projet EF). Bon, voilà le contexte générale.

    Mon problème réside entre 2 entités :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
     
        [Table("RdV")]
        public class Rdv
        {
            [Key]
            [Column("Numero")]
            public string RdvID { get; set; }
     
            [Column("Projet")]
            public int? Projet { get; set; }
     
            [Column("Societe")]
            public string Societe { get; set; }
     
          ...
     
            public virtual ParametresRdV ParametresRdV { get; set; }
     
        }
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
        [Table("ParametresRdV")]
        public class ParametresRdV
        {
            [Key]
            [Column("Numero")]
            public int ParametresRdVID { get; set; }
     
            [Column("NumeroRdv")]
            public string NumeroRdv { get; set; }
     
            [Column("DateRdv")]
            public string DateRdv { get; set; }
     
          ...
     
            [ForeignKey("NumeroRdv")]
            public virtual Rdv Rdv { get; set; }
     
        }
    Voici le message de l'exception qui est levée :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Unable to determine the principal end of an association between the types 'xxxxx.Models.ParametresRdV' and 'xxxxxx.Models.Rdv'. The principal end of this association must be explicitly configured using either the relationship fluent API or data annotations.

    Le soucis, c'est qu'a la compilation, EF ne parvient pas à déterminer la relation entre Rdv et ParametresRdv. J'ai vu plusieurs sujet et articles sur le sujet mais rien ne fonctionne. J'ai vu des choses sur Fluant Entity mais n’ai pas encore essayé.

    Merci de m'avoir lu et j'espère que vous m'apporterez la solution comme le messie

  2. #2
    Membre expert
    Avatar de GuruuMeditation
    Homme Profil pro
    .Net Architect
    Inscrit en
    Octobre 2010
    Messages
    1 705
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : Belgique

    Informations professionnelles :
    Activité : .Net Architect
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2010
    Messages : 1 705
    Points : 3 568
    Points
    3 568
    Par défaut
    Pas sûr, mais je me demande si il n'y a pas une convention pour les foreign key, et elle doivent se terminer par "Id"
    Microsoft MVP : Windows Platform

    MCPD - Windows Phone Developer
    MCPD - Windows Developer 4

    http://www.guruumeditation.net

    “If debugging is the process of removing bugs, then programming must be the process of putting them in.”
    (Edsger W. Dijkstra)

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Février 2006
    Messages
    136
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 136
    Points : 65
    Points
    65
    Par défaut
    Salut,

    En théorie oui, c'est le cas. MMais l'annotation de foreignkey permet justement de contourner cette norme. Mais j'ai essayé avec ID je te rassure.mais non, cela ne fonctionne pas.

  4. #4
    Rédacteur
    Avatar de The_badger_man
    Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2005
    Messages
    2 745
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2 745
    Points : 8 538
    Points
    8 538
    Par défaut
    As-tu essayé en mettant un [Key, ForeignKey("Rdv")] sur la propriété ParametresRdVID ?
    Les règles du forum
    Le trio magique : FAQ + Cours + fonction rechercher
    Mes articles
    Pas de questions par messages privés svp

    Software is never finished, only abandoned.

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Février 2006
    Messages
    136
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 136
    Points : 65
    Points
    65
    Par défaut
    Bonjour,

    Je n'etais pas toimbé sur cette syntaxe d'annotation. mais la solution a été trouvé. En utilisant Fluent tout ce petit monde fonctionne bien ensemble.

    petite explication. Dans la classe de context, il faut surcharger OnModelCreating comme ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
            protected override void OnModelCreating(DbModelBuilder modelBuilder)
            {
                modelBuilder.Entity<Rdv>().HasKey<string>(t => t.RdvID);//oui, une clé en string. C'est pas ma faute ! :s
                modelBuilder.Entity<ParametresRdV>().HasKey(t => t.ParametresRdVID);
                modelBuilder.Entity<ParametresRdV>().HasRequired(t => t.Rdv).WithOptional(t => t.ParametresRdVs);
                base.OnModelCreating(modelBuilder);
            }
    Merci pour vos réponses en tout cas

Discussions similaires

  1. [2.x] Relation entre les entités
    Par sipompom dans le forum Symfony
    Réponses: 4
    Dernier message: 29/07/2014, 12h04
  2. [2.x] Les voters et la relation entre les entités
    Par hous04 dans le forum Symfony
    Réponses: 4
    Dernier message: 02/06/2014, 15h45
  3. Réponses: 4
    Dernier message: 17/05/2013, 14h18
  4. Relation entre les tables
    Par adelyx dans le forum Bases de données
    Réponses: 1
    Dernier message: 02/04/2005, 23h06
  5. Relations entre les Paquetages
    Par bran_noz dans le forum UML
    Réponses: 4
    Dernier message: 25/06/2004, 14h05

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