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 :

Problème de join ou de where :/


Sujet :

Linq

Vue hybride

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

    Homme Profil pro
    Développeur .NET
    Inscrit en
    Juillet 2009
    Messages
    966
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Juillet 2009
    Messages : 966
    Par défaut Problème de join ou de where :/
    Bonjour a tous,
    voila j'ai un petit problème.

    j'ai 3 tables : article, caractéristique et une table intermédiaire entre ses 2 tables.


    par une méthode je récupère une liste d'ID de caractéristique, jusque la pas de souci.

    J'utilise alors cette liste pour récupérer les ID articles correspondant a ses caractéristiques via une méthode Contains.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    var query = from c in chart.GetData()
               where IdCharac.Contains(c.Characteristics_idCharacteristics)
               select c.Articles_idArticles;
    forcement je récupère les articles qui possèdent au moins une caractéristique contenu dans ma liste... or se que je veux c'est avoir uniquement ceux qui possède toute ses caractéristiques.

    j'ai essayer par un joins mais sa ne marche pas mieux...

    bref si quelqu'un peut m'aider,
    par avance merci!

    Yoyo88 (qui galère bien! )

  2. #2
    Membre éclairé

    Homme Profil pro
    Développeur .NET
    Inscrit en
    Juillet 2009
    Messages
    966
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Juillet 2009
    Messages : 966
    Par défaut
    et bien il semble que j'ai trouver une solution

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    var art = (from c in chart.GetData()
           join i in IdCharac.ToList() on c.Characteristics_idCharacteristics equals i
           select new { c.Articles_idArticles, c.Characteristics_idCharacteristics }).Distinct();
     
    var req = from a in art.ToList()
           group a by a.Articles_idArticles into i
           where i.Count() == IdCharac.Count()
           select new { i.Key };
    Je sélectionne dans un premier temps une liste ID article et de ID Caractéristique
    j'ai donc une liste du style
    IDart IDCarac
    1 1
    1 2
    2 1
    3 1
    4 2

    puis je regroupe ma liste par IdArticle et je compte le nombre de caractéristique

    j'ai donc
    IDart NBIDCarac
    1 2
    2 1
    3 1
    4 1

    or comme je sais que j'ai X caractéristique...


    Apres je me demande si il n'y a pas une meilleurs solution...
    si quelqu'un a une idée sa m’intéresse.

  3. #3
    Membre émérite
    Homme Profil pro
    Développeur / architecte
    Inscrit en
    Juillet 2009
    Messages
    473
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Développeur / architecte

    Informations forums :
    Inscription : Juillet 2009
    Messages : 473
    Par défaut
    Je crois que la réponse à ta question est la méthode linq "intersect"... (rappelle toi tes vieux cours sur les ensembles ) Voir ici

  4. #4
    Membre éclairé

    Homme Profil pro
    Développeur .NET
    Inscrit en
    Juillet 2009
    Messages
    966
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Juillet 2009
    Messages : 966
    Par défaut
    Citation Envoyé par chrisdot Voir le message
    Je crois que la réponse à ta question est la méthode linq "intersect"... (rappelle toi tes vieux cours sur les ensembles ) Voir ici
    j'ai regarder intersect sauf que si j'ai ma table intermédiaire

    qui contient la liste de mes IDArticle et IDCarac
    IDart IDCarac
    1 1
    1 2
    2 1
    3 1
    4 2
    5 3
    5 3
    6 4

    et ma liste en entrer corespond au IDCarac ( ID 1 et 2 par exemple)
    or l'intersect entre les 2 liste va me sortir :
    IDart IDCarac
    1 1
    1 2
    2 1
    3 1
    4 2

    bref tous les enregistrement ayant au moins 1 ou 2 dans l'IDCarac or moi je veut uniquement les Id article qui correspond au 2 carac uniquement. donc je doit faire automatiquement un regroupement.

    se qui correspond en faite a se que j'ai fait.

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

Discussions similaires

  1. [performance] condition dans le join ou le where ?
    Par Satch dans le forum Langage SQL
    Réponses: 3
    Dernier message: 28/09/2006, 00h04
  2. Réponses: 5
    Dernier message: 10/07/2006, 13h05
  3. [MySQL] INNER & OUTER JOIN imbriqués avec WHERE
    Par kelson dans le forum Langage SQL
    Réponses: 1
    Dernier message: 28/02/2006, 13h00
  4. problème d'utilisation du JOIN et du WHERE
    Par GphyProg dans le forum Requêtes
    Réponses: 11
    Dernier message: 20/12/2005, 20h23
  5. [Debutant][Join Sql] problème de join
    Par ultimax dans le forum Langage SQL
    Réponses: 4
    Dernier message: 16/11/2004, 13h01

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