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

Linq Discussion :

Lambda expressions Multiple join


Sujet :

Linq

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert

    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2010
    Messages
    2 067
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Novembre 2010
    Messages : 2 067
    Par défaut Lambda expressions Multiple join
    Bonjour,

    j'essaye de créer une requête linq en utilisant les expression lambda qui join trois table, j'ai vu comment on pouvait joindre 2 tables mais pour 3 j'ai pas trouvé.
    J'ai réussi à écrire une requête linq fonctionnel mais j'aimerais bien pouvoir la réécrire en utilisant les expression lambda.

    J'ai donc trois table:
    - une carnet d'adresse contenant les différents utilisateur
    - une contact contenant les différents contact et leur information
    - une annuaire contenant les différentes société

    dans contact j'ai une clé étrangère pointant sur carnet d'adresse et une autre sur annuaire.

    Et je voudrais donc retrouvé toutes les société référencé pour un utilisateur donné:

    Voici un résultat fonctionnel en sql et un autre en linq:
    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
    20
    21
    22
     
    select * from TRD_ANNUAIRE a
    join TRD_CONTACT c on a.SOA_ID=c.CTA_SOA_ID
    join TRD_CARNET_ADRESSE ca on c.CTA_ID=ca.CAD_CTA_ID
    where ca.CAD_USR_CODE=1
     
    List<SocieteAnnuaireCompatible> test = (from a in database.TRD_ANNUAIRE
                                                                join c in database.TRD_CONTACT on a.SOA_ID equals c.CTA_SOA_ID
                                                                join ca in database.TRD_CARNET_ADRESSE on c.CTA_ID equals ca.CAD_CTA_ID
                                                                where ca.CAD_USR_CODE == code_uti
                                                                select new SocieteAnnuaireCompatible
                                                                {
                                                                    Nom = a.SOA_NOM,
                                                                    Adresse = a.SOA_ADRESSE,
                                                                    CodePostal = a.SOA_CODE_POSTAL,
                                                                    Email = a.SOA_EMAIL,
                                                                    Fax = a.SOA_FAX,
                                                                    Id = a.SOA_ID,
                                                                    Gsm = a.SOA_GSM,
                                                                    Telephone = a.SOA_TELEPHONE,
                                                                    Ville = a.SOA_VILLE
                                                                }).Distinct().ToList();
    Si quelqu'un pourrait m'aider à créer cette requête merci.

  2. #2
    Rédacteur
    Avatar de Nathanael Marchand
    Homme Profil pro
    Expert .Net So@t
    Inscrit en
    Octobre 2008
    Messages
    3 615
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Expert .Net So@t
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2008
    Messages : 3 615
    Par défaut
    C'est une erreur souvent effectuée par les débutants en Linq mais si l'EDMX est correctement modélisé, il n'y a pas à faire de jointures! En effet, ton objet possède des propriétés pour naviguer de le graph d'objet, c'est fait automatiquement et de manière transparente.

  3. #3
    Membre Expert

    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2010
    Messages
    2 067
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Novembre 2010
    Messages : 2 067
    Par défaut
    je n'utilise pas d'edmx mais un dbml (pas tapé)
    après je sais pas si on peut faire la même chose avec

  4. #4
    Rédacteur
    Avatar de Nathanael Marchand
    Homme Profil pro
    Expert .Net So@t
    Inscrit en
    Octobre 2008
    Messages
    3 615
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Expert .Net So@t
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2008
    Messages : 3 615
    Par défaut
    Citation Envoyé par youtpout978 Voir le message
    je n'utilise pas d'edmx mais un dbml (pas tapé)
    après je sais pas si on peut faire la même chose avec
    Le principe est le même, il y'a des liaisons entre les entités

  5. #5
    Membre Expert

    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2010
    Messages
    2 067
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Novembre 2010
    Messages : 2 067
    Par défaut
    merci je partais de la mauvaise base aussi voici le résultat fonctionnel
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    List<SocieteAnnuaireCompatible> test = database.TRD_CARNET_ADRESSE.Where(d => d.CAD_USR_CODE == code_uti).Select(c => new SocieteAnnuaireCompatible
                        {
                            Nom = c.TRD_CONTACT.TRD_ANNUAIRE.SOA_NOM,
                            Adresse = c.TRD_CONTACT.TRD_ANNUAIRE.SOA_ADRESSE,
                            CodePostal = c.TRD_CONTACT.TRD_ANNUAIRE.SOA_CODE_POSTAL,
                            Email = c.TRD_CONTACT.TRD_ANNUAIRE.SOA_EMAIL,
                            Fax = c.TRD_CONTACT.TRD_ANNUAIRE.SOA_FAX,
                            Id = c.TRD_CONTACT.TRD_ANNUAIRE.SOA_ID,
                            Gsm = c.TRD_CONTACT.TRD_ANNUAIRE.SOA_GSM,
                            Telephone = c.TRD_CONTACT.TRD_ANNUAIRE.SOA_TELEPHONE,
                            Ville = c.TRD_CONTACT.TRD_ANNUAIRE.SOA_VILLE
                        }).Distinct().ToList();
    y'a t'il un moyen de remplacer c.TRD_CONTACT.TRD_ANNUAIRE par un alias

  6. #6
    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 : 43
    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
    Par défaut
    Citation Envoyé par youtpout978 Voir le message
    y'a t'il un moyen de remplacer c.TRD_CONTACT.TRD_ANNUAIRE par un alias
    Tu peux renommer les classes et les propriétés dans ton DBML

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 25/04/2011, 23h23
  2. Lambda expression et pseudo reflection
    Par zax-tfh dans le forum VB.NET
    Réponses: 0
    Dernier message: 28/10/2010, 15h21
  3. lambda expression et gridview
    Par topolino dans le forum ASP.NET
    Réponses: 5
    Dernier message: 04/03/2010, 13h18
  4. Je n'arrive pas à utiliser les Lambda Expressions
    Par Tiber_le_vrai dans le forum C#
    Réponses: 7
    Dernier message: 21/12/2009, 14h41
  5. [Lambda]Problèmes avec les lambdas expressions
    Par sarapis dans le forum Général Dotnet
    Réponses: 8
    Dernier message: 25/06/2008, 13h53

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