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 :

[VB.Net] Grouper sur 2 colonnes et faire une somme. [Débutant]


Sujet :

Linq

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Novembre 2010
    Messages
    56
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2010
    Messages : 56
    Points : 41
    Points
    41
    Par défaut [VB.Net] Grouper sur 2 colonnes et faire une somme.
    Bonjour à tous,
    Je programme sous VB.Net 2010 et je tente d'utiliser Linq pour trouver une solution à mon probléme. C'est le premier problème que j'essai de résoudre avec Linq mais je tourne en rond et aujourd'hui je fais appel à vous. Voici l'énoncé de mon problème :
    J'ai une dataTable (nommée maTableAno) qui contient 7 champs et dont voici un extrait :
    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
    Type   	        Jour              	Heure                   Sectime   	Duree	Symbole	Valeur
    Depassement	02/01/2012 00:00	30/12/1899 01:10:00	1009933800	10	CO	191
    Depassement	02/01/2012 00:00	30/12/1899 05:00:00	1009947600	30	COVT	38
    Depassement	02/01/2012 00:00	30/12/1899 07:50:00	1009957800	10	CO	303
    Depassement	02/01/2012 00:00	30/12/1899 10:00:00	1009965600	30	COVT	47
    Depassement	04/01/2012 00:00	30/12/1899 09:20:00	1010136000	10	CO	690
    Depassement	04/01/2012 00:00	30/12/1899 10:40:00	1010140800	10	CO	382
    Depassement	04/01/2012 00:00	30/12/1899 14:30:00	1010154600	30	COVT	37
    Depassement	04/01/2012 00:00	30/12/1899 15:10:00	1010157000	10	CO	427
    Depassement	05/01/2012 00:00	30/12/1899 09:30:00	1010223000	30	COVT	20
    Depassement	05/01/2012 00:00	30/12/1899 10:00:00	1010224800	30	COVT	24
    Depassement	05/01/2012 00:00	30/12/1899 11:50:00	1010231400	10	CO	547
    Depassement	05/01/2012 00:00	30/12/1899 12:30:00	1010233800	10	CO	169
    Depassement	07/01/2012 00:00	30/12/1899 17:00:00	1010422800	10	CO	164
    Depassement	07/01/2012 00:00	30/12/1899 19:20:00	1010431200	10	CO	1833
    Maintenant je voudrais grouper les champs qui ont le même jour et le même symbole et faire la somme de "Duree". J'obtiendrais par exemple :
    02/01/2012, CO, 20
    02/01/2012, COVT, 60
    (pour info, à ce point du programme, les autres champs ne me servent plus à rien).
    Voila çi dessous, le code que j'ai tenté de faire mais cette requête n'est même pas compilable. Le message d'erreur se trouve au niveau de g.Sum et il affiche : "Le nom de la variable de portée peut être déduit uniquement à partir d'un nom qualifié ou d'un nom simple sans arguments".
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    Dim maTableAno = _gestionnaireAnomalies.AnomaliesDepSansConcomitances(_proprietaire.Code, dateDebut, dateFin)
     
                        Dim maRequeteLinq = From element In maTableAno.AsEnumerable() _
                                            Group element By Jour = element.Field(Of DateTime)("Jour"), Symbole = element.Field(Of String)("Symbole") Into g = Group _
                                            Select Jour.Date, Symbole, g.Sum(Function(x) x.Duree)
                                            Order By [Date]
    Voila toute l'histoire, alors si quelqu'un pouvait me dépanner je lui en serais très reconnaissant. Merci à tous.

    Bonne journée.
    Thierry

  2. #2
    Membre du Club
    Profil pro
    Inscrit en
    Novembre 2010
    Messages
    56
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2010
    Messages : 56
    Points : 41
    Points
    41
    Par défaut
    Bonjour à tous,
    Je répond à moi-même. Après avoir cherché et fait des recoupages avec de multiples requêtes d'exemples je suis arrivé à la requête suivante qui fonctionne apparement sans problèmes suite à mes tests. Pour info je vous donne la réponse à ma question. Si ça peut aider quelqu'un !
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    Dim maTableDepNet As IEnumerable = (From element In maTableAno.AsEnumerable() _
                                                            Group element By leJour = element.Item(1), leSymbole = element.Item(5) _
                                                            Into g = Group _
                                                            Select New With {.Jour = leJour, .Symbole = leSymbole, .DureeTotale = New TimeSpan(0, 0, g.Sum(Function(x) x.Item(4)))}).ToList
    Dans le code, le "New TimeSpan" permet de faire la somme, en secondes, de la colonne "Duree".

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

Discussions similaires

  1. [SP-2010] Faire une somme sur une colonne d'une liste
    Par sebfreu dans le forum SharePoint
    Réponses: 6
    Dernier message: 19/01/2012, 11h05
  2. [XL-2003] faire une somme que sur les colonnes visibles
    Par mimilll dans le forum Excel
    Réponses: 21
    Dernier message: 27/08/2009, 12h10
  3. Réponses: 4
    Dernier message: 16/02/2009, 13h42
  4. faire une somme recursive sur 1 colonne sur 2 dates consecutives et l'afficher
    Par 461219 dans le forum Adaptive Server Enterprise
    Réponses: 12
    Dernier message: 24/11/2008, 16h09
  5. [VB.NET] Erreur sur la creation dynamique d'une texbox
    Par headcooper dans le forum ASP.NET
    Réponses: 4
    Dernier message: 01/07/2004, 19h34

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