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 :

[C#] Requête linq avec groupby et jointure


Sujet :

Linq

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    849
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2004
    Messages : 849
    Points : 295
    Points
    295
    Par défaut [C#] Requête linq avec groupby et jointure
    Salut a tous,

    Je n'arrive pas à traduire une requête sql en linq.
    Je sais faire une jointure en linq, mais après je n'arrive pas à faire le count.

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    select a.id, a.libelle, COUNT(*) nb
    from  a
    join b on a.Id = b.IdEtrangere 
    group by a.id, a.libelle

    Merci de m'aider.

  2. #2
    Membre régulier
    Homme Profil pro
    Inscrit en
    Avril 2010
    Messages
    152
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2010
    Messages : 152
    Points : 109
    Points
    109
    Par défaut
    Bonjour,

    Une petite recherche sur le net :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    from p in context.ParentTable
    join c in context.ChildTable on p.ParentId equals c.ChildParentId into j1
    from j2 in j1.DefaultIfEmpty()
    group j2 by p.ParentId into grouped
    select new { ParentId = grouped.Key, Count = grouped.Count(t=>t.ChildId != null) }

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Développeur Java
    Inscrit en
    Août 2011
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Chine

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Août 2011
    Messages : 15
    Points : 25
    Points
    25
    Par défaut
    Bonjour,

    Tu as envie de deux colonnes comme key, pas une colonne comme normal.
    D'abord, tu peux sélectionner tous les données de la table a, après sélectionnes les données distinctes. En suite, joins la table b.
    Essaye le code suivant:
    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
     
    var q = from m in
                (from t1 in a
                 select new
                 {
                     t1.id,
                     t1.libelle
                 }).Distinct()
            join t2 in b on m.id equals t2.IdEtrangere
            into d
            select new
            {
                m.id,
                m.libelle,
                np = d.Count()
            };

  4. #4
    Candidat au Club
    Homme Profil pro
    Architecte technique
    Inscrit en
    Janvier 2014
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Architecte technique

    Informations forums :
    Inscription : Janvier 2014
    Messages : 3
    Points : 4
    Points
    4
    Par défaut
    Essayer l'opérateur .QueryByCube() (voir www.adaptivelinq.com), c'est typiquement fait pour faire ce type de requête.
    "id" et "libelle" sont des dimensions
    "nb" est une mesure

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

Discussions similaires

  1. Aide sur une requête LINQ avec left outer join
    Par jbrasselet dans le forum Linq
    Réponses: 5
    Dernier message: 12/09/2011, 09h31
  2. Requête Hibernate avec criteria en jointure
    Par Zodoh dans le forum Hibernate
    Réponses: 0
    Dernier message: 08/10/2010, 10h56
  3. Liaison requête Linq avec un bindingSource
    Par 0redd dans le forum Linq
    Réponses: 4
    Dernier message: 13/08/2010, 00h14
  4. Réponses: 1
    Dernier message: 08/05/2010, 16h35
  5. requête linq avec Delphi ?
    Par sam-sam dans le forum Bases de données
    Réponses: 1
    Dernier message: 02/09/2009, 15h21

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