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 :

récupérer la valeur d'un champs ( clé étrangère)


Sujet :

Entity Framework

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

    Informations forums :
    Inscription : Décembre 2006
    Messages : 57
    Points : 42
    Points
    42
    Par défaut récupérer la valeur d'un champs ( clé étrangère)
    Bonjour,

    J'utilise actuellement entity framework sur une base de données mysql.

    J'ai ajouter 2 table a mon model

    Produits et marque
    donc un produit possede une marque

    avec une requete linq on obtient

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    var q = from c in context.produits
                        select c;
    le probleme est que la valeur de c.marques est null .

    Comment récupérer cette valeur ou faire une jointure ?

    merci

  2. #2
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 749
    Points
    39 749
    Par défaut
    Par défaut, Entity Framework ne charge pas les associations, pour éviter de charger inutilement un énorme graphe d'objets. Si tu as besoin de charger une association en particulier, tu peux l'indiquer avec Include :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    var q = from c in context.Produits.Include("Marques")
            select c;

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

    Informations forums :
    Inscription : Décembre 2006
    Messages : 57
    Points : 42
    Points
    42
    Par défaut
    super merci , je vais tester ce midi.

    par contre j'ai vu qu'avec MARS(Multiple Active Result Sets) , on pouvais charger automatiquement les données des tables en relation.

    peut-on activer mars sur mysql ?

    merci

  4. #4
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 749
    Points
    39 749
    Par défaut
    Citation Envoyé par superkiller Voir le message
    par contre j'ai vu qu'avec MARS(Multiple Active Result Sets) , on pouvais charger automatiquement les données des tables en relation.

    peut-on activer mars sur mysql ?
    Je connais pas trop, mais il me semble que c'est spécifique à SQL Server, non ?

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

    Informations forums :
    Inscription : Décembre 2006
    Messages : 57
    Points : 42
    Points
    42
    Par défaut
    apparemment oui , ca marche que sur sql server et oracle.

  6. #6
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    57
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 57
    Points : 42
    Points
    42
    Par défaut
    j'ai essayé ta solution , mais je n'est pas de include dans mon context.

    Comment puis-je l'obtenir ?

    merci

  7. #7
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 749
    Points
    39 749
    Par défaut
    Citation Envoyé par superkiller Voir le message
    j'ai essayé ta solution , mais je n'est pas de include dans mon context.
    Ce n'est pas sur l'ObjectContext qu'il faut appeler Include, mais sur l'ObjectQuery (produits)... relis mon exemple de code

  8. #8
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    57
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 57
    Points : 42
    Points
    42
    Par défaut
    ok merci , je vais réessayer après 17h30 , jte tiens au courant mais il me semble que je l'avais fait sur produits.

    a toute merci

  9. #9
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    57
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 57
    Points : 42
    Points
    42
    Par défaut
    alors , j'ai reglé le probleme.

    je n'avais pas la méthode include car elle s'utilise avec des objectsQuery hors moi il s'agit de DataServiceQuery.

    Avec ce type d'objet on utilise la méthode "expand" .

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

Discussions similaires

  1. Réponses: 7
    Dernier message: 15/09/2005, 06h37
  2. API pour récupérer la valeur d'un champ Edit
    Par buteiduil dans le forum Windows
    Réponses: 4
    Dernier message: 15/05/2005, 22h32
  3. Réponses: 1
    Dernier message: 22/02/2005, 23h40
  4. Récupérer la valeur d'un champ disabled
    Par nebule dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 27/01/2005, 10h45
  5. récupérer la valeur du 2ème champ dans un DBLookUpListBox
    Par jakouz dans le forum Bases de données
    Réponses: 3
    Dernier message: 20/07/2004, 16h45

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