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

C# Discussion :

Binder un DataGridView à partir de 3 tables avec EF


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Janvier 2011
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2011
    Messages : 9
    Par défaut Binder un DataGridView à partir de 3 tables avec EF
    Bonjour, voici mon problème:

    j'ai une table Commande(id..) qui est relié en n-n à une table Produit(id,libelle,prix)
    Cela me donne la table LigneCommande(idCom,idProd,quantite)

    je voudrais afficher dans un DataGridView Libelle Prix Quantite pour chaque Ligne de Commande

    j'avais lu une solution pour binder à partir d'une table avec clé étrangère mais je n'ai pas trouver pour une table d'association nn.

    voici ce que j'ai essayé :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    this.DGV.DataSource = from P in Entity.Produits
                                   from L in Entity.LignesCommandes
                                   from C in Entity.Commandes
    where P.Identifiant == L.IdentifiantProduit && 
    C.Identifiant == L.IdentifiantCommande && 
    C.Identifiant == commande.Identifiant
                                                              select new
                                                              {
                                                                  Produit = P.Libelle,
                                                                  Quantité = quantite,
                                                                  Prix = P.Prix
                                                              };
    mais cela ne marche pas.
    Avez vous une solution à partir de cela
    ou sinon comment peut on faire avec le Linq to Entity??

    merci

  2. #2
    Membre émérite Avatar de NicoL__
    Homme Profil pro
    Architecte
    Inscrit en
    Janvier 2011
    Messages
    399
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Architecte

    Informations forums :
    Inscription : Janvier 2011
    Messages : 399
    Par défaut
    Je pense que cette requête doit mieux marcher :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
     
    this.DGV.DataSource = from P in Entity.Produits
                                   join L in Entity.LignesCommandes 
                                            on P.Identifiant equals L.IdentifiantProduit
                                   join C in Entity.Commandes
                                            on L.IdentifiantCommande equals C.Identifiant
    where  C.Identifiant == commande.Identifiant
                                                              select new
                                                              {
                                                                  Produit = P.Libelle,
                                                                  Quantité = quantite,
                                                                  Prix = P.Prix
                                                              };

Discussions similaires

  1. Réponses: 6
    Dernier message: 21/12/2012, 00h14
  2. Réponses: 6
    Dernier message: 15/06/2010, 03h18
  3. Réponses: 1
    Dernier message: 20/02/2008, 11h34
  4. Réponses: 2
    Dernier message: 19/06/2007, 11h00
  5. [SQL] Liste déroulante à partir d'une table avec tri
    Par ksper92 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 28/11/2006, 11h25

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