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

Framework .NET Discussion :

[LINQ] Distinct et doublons


Sujet :

Framework .NET

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Mars 2008
    Messages
    22
    Détails du profil
    Informations forums :
    Inscription : Mars 2008
    Messages : 22
    Par défaut [LINQ] Distinct et doublons
    Salut à tous !

    Je viens vers vous car apres plus d'une journée complete de recherche et de tatonnage, je ne m'en sors pas...

    Pour commencer, voici ma requette LINQ simplifiée :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    var obj = from t1 in db.Table1
              join t2 in db.Table2 on t1.a_ID equals t2.a_ID into l1
              from t2 in l1
              join t3 in db.Table3 on t1.b_ID equals t3.b_ID into l2
              from t3 in l2
              where iList.Contains(t3.anID)
              select new
              {
                  champs0 = t1.b_ID,
                  champs1 = t1.champs,
                  champs2 = t2.champs,
                  champs3 = t3.champs,
              };
    iList est donc un "List<int>" contenant une liste d'ID ("anID" de la table "Table3").

    La requette fonctionne, mais me ramene des doublons. En effet, la "Table3" peut contenir plusieurs fois des "b_ID" mais avec des "anID" différents.

    Je voudrai seulement ramener des elements dont les b_ID sont différents. Comment enlever ces doublons? Le méthode Distinct n'a pas l'air d'avoir d'effet. Peut etre que je l'utilise mal...

    J'espere avoir été assez clair ! Parceque c'est pas simple

    Merci à tous par avance!

  2. #2
    Rédacteur
    Avatar de Thomas Lebrun
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    9 161
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 9 161
    Par défaut
    Comme ca ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    var obj = from t1 in db.Table1
              join t2 in db.Table2 on t1.a_ID equals t2.a_ID into l1
              from t2 in l1
              join t3 in db.Table3 on t1.b_ID equals t3.b_ID into l2
              from t3 in l2
              where iList.Contains(t3.anID).Distinct()
              select new
              {
                  champs0 = t1.b_ID,
                  champs1 = t1.champs,
                  champs2 = t2.champs,
                  champs3 = t3.champs,
              };

  3. #3
    Membre averti
    Inscrit en
    Mars 2008
    Messages
    22
    Détails du profil
    Informations forums :
    Inscription : Mars 2008
    Messages : 22
    Par défaut
    Salut Thomas!
    Il n'y a pas la possibilité de le faire à cette endroit.

    Je l'ai fais sur l'objet final sans résultats.

    A priori, le Distinct() devrai se faire uniquement sur le b_ID et non sur les autres champs. J'ai essayer de construire une classe pour comparer mais sans résultats...

Discussions similaires

  1. Linq, Distinct et new sur des collections
    Par tfrancais dans le forum Linq
    Réponses: 1
    Dernier message: 01/09/2009, 09h32
  2. Problème DISTINCT et doublons
    Par gcef13 dans le forum Langage SQL
    Réponses: 6
    Dernier message: 21/01/2009, 22h26
  3. [Linq] exclure les doublons d'une requete
    Par ZaaN dans le forum C#
    Réponses: 1
    Dernier message: 03/01/2008, 15h32
  4. Réponses: 3
    Dernier message: 13/04/2007, 16h00
  5. doublons avec distinct
    Par deubal dans le forum Langage SQL
    Réponses: 1
    Dernier message: 18/11/2005, 17h07

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