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 :

Impossible de récupérer une somme dans une liste à partir d'un DataView


Sujet :

Linq

  1. #1
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Août 2013
    Messages
    18
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Août 2013
    Messages : 18
    Points : 15
    Points
    15
    Par défaut Impossible de récupérer une somme dans une liste à partir d'un DataView
    Bonjour tout le monde,

    J'essaye d'obtenir une somme à partir d'une liste provenant d'un dataview contenant un group by.

    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
    17
        DataView view = _objManager.ACCOUNTS.DefaultView;
     
                            // Set RowStateFilter to display the current rows.
                            view.RowStateFilter = DataViewRowState.CurrentRows;
     
                            var res = ((DataTable)view.Table)
                              .AsEnumerable()
                              .GroupBy(row => new { ID = row.Field<long?>("ID"), ELEM = row.Field<string>("ELEM") })
                              .Select(sel => new
                              {
                                  NAME = sel.First()["NAME"],
                                  ID = sel.First()["ID"],
                                  IBAN = sel.First()["IBAN"],
                                  BIC = sel.First()["BIC"],
                                  INFO = sel.First()["INFO"],
    			      AMOUNT= sel.Sum(s => sel.Sum()["AMOUNT"])  //ne marche pas                           
                              }).ToList();
    Mais le sum ne compile pas.
    Avez vous une idée ?
    Merci beaucoup par avance.
    Eric

  2. #2
    Expert confirmé
    Avatar de popo
    Homme Profil pro
    Analyste programmeur Delphi / C#
    Inscrit en
    Mars 2005
    Messages
    2 669
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Analyste programmeur Delphi / C#
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 2 669
    Points : 5 238
    Points
    5 238
    Par défaut
    La requête qui construit ta vue possède un group by.
    Mais les lignes en résultant n'en n'ont pas !

    Et donc ceci devrait suffire.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    var res = table
        .GroupBy(row => new { row.Id, row.Elem })
        .Select(group => new { Line = group.Key, Amount = group.Sum(row => row.Amount) }).ToList();;

Discussions similaires

  1. Recherche dans une table : impossible de récupérer une saisie
    Par wolfenjava dans le forum Débuter avec Java
    Réponses: 6
    Dernier message: 21/07/2012, 21h04
  2. Impossible de récupérer ma webcam dans une applet
    Par drasalmed dans le forum Applets
    Réponses: 0
    Dernier message: 07/01/2011, 16h29
  3. [SOAP][PHP5] impossible de récupérer une données sur un appel
    Par gentony dans le forum XML/XSL et SOAP
    Réponses: 3
    Dernier message: 24/09/2009, 16h08
  4. Réponses: 3
    Dernier message: 16/07/2008, 11h01
  5. Réponses: 1
    Dernier message: 19/04/2008, 16h26

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