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 :

Requete avec count/group/average


Sujet :

Linq

  1. #1
    Inactif  
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Août 2011
    Messages
    26
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2011
    Messages : 26
    Points : 20
    Points
    20
    Par défaut Requete avec count/group/average
    Bonjour,

    J'ai une requête sql qui ressemble à ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    select avg(cast(computerPerUser as float)) as taux, SUM(computerPerUser) as totalNbrComputer 
    from( 
    SELECT count(ComputerName) as computerPerUser,user_id 
      FROM MaTable
      where  ComputerName is not null 
      group by USER_ID) sub
    Je souhaiterais réaliser la même chose avec linq, j'ai déjà fait la sous requête par contre pour la suite je sèche :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    var v = from ratios in MaTable
              where ratios.ComputerName != null 
              group ratios by ratios.USER_ID into grouping 
              select new { useruid = grouping.Key, compPerUser = grouping.Count() };
    Merci.

  2. #2
    Modérateur
    Avatar de DotNetMatt
    Homme Profil pro
    CTO
    Inscrit en
    Février 2010
    Messages
    3 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : CTO
    Secteur : Finance

    Informations forums :
    Inscription : Février 2010
    Messages : 3 611
    Points : 9 743
    Points
    9 743
    Billets dans le blog
    3
    Par défaut
    Il y a plusieurs réponses possibles...

    La première consiste à consommer le résultat de ta variable v
    Code C# : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    var avg = v.Average(x => x.compPerUser);
    var sum = v.Sum(x => x.compPerUser);
    Une autre façon de faire, tout d'un coup :
    Code C# : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    var sum = MaTable
    	  .GroupBy(x => x.USER_ID)
    	  .Sum(x => x.Count(y => !string.IsNullOrEmpty(y.ComputerName)));
     
    var avg = MaTable
    	  .GroupBy(x => x.USER_ID)
    	  .Average(x => x.Count(y => !string.IsNullOrEmpty(y.ComputerName)));
    Less Is More
    Pensez à utiliser les boutons , et les balises code
    Desole pour l'absence d'accents, clavier US oblige
    Celui qui pense qu'un professionnel coute cher n'a aucune idee de ce que peut lui couter un incompetent.

  3. #3
    Inactif  
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Août 2011
    Messages
    26
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2011
    Messages : 26
    Points : 20
    Points
    20
    Par défaut
    Merci pour ton aide Matt.

    Finalement j'ai résolu le problème avec deux requêtes, je ne pourrais te dire comment car depuis hier j'ai revu une bonne partie du projet car j'avais des problèmes de perf (non liées à linq). Du coup ma petite requête sur laquelle j'ai passé un peu de temps est devenu inutile et a été supprimé...néanmoins la solution que tu me proposes sera susceptible de me servir dans un avenir plus ou moins proche, donc je garde ça au chaud.

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

Discussions similaires

  1. [mysql 5] requete avec count+ having + group by
    Par epeichette dans le forum Requêtes
    Réponses: 7
    Dernier message: 29/10/2008, 19h52
  2. Requetes Avec Count et condition sur date
    Par Harry dans le forum WinDev
    Réponses: 1
    Dernier message: 04/06/2007, 15h23
  3. Comment optimiser une Requete avec Count ?
    Par tavarlindar dans le forum Requêtes
    Réponses: 15
    Dernier message: 09/02/2007, 21h19
  4. Requete SQL : COUNT GROUP BY
    Par Florent08800 dans le forum Requêtes
    Réponses: 3
    Dernier message: 06/10/2006, 10h04
  5. requete avec jointure & group by
    Par de LANFRANCHI dans le forum Langage SQL
    Réponses: 9
    Dernier message: 27/07/2004, 14h31

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