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

MS SQL Server Discussion :

Regroupement avec GROUP BY


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Inscrit en
    Mai 2008
    Messages
    298
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 298
    Par défaut Regroupement avec GROUP BY
    Bonjour,

    J'aimerais regrouper mes valeurs en fonction d'une date.

    Voici mes données:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    'Id' - 'Date' - 'Valeur 1' - 'Valeur 2'
    1 - 2010-05-03 08:01:22 - 0 - 0
    2 - 2010-05-03 08:54:22 - 1 - 0
    3 - 2010-05-03 09:12:22 - 1 - 1
    4 - 2010-05-04 09:15:22 - 0 - 1
    5 - 2010-05-04 11:02:22 - 1 - 1
    6 - 2010-05-05 12:39:22 - 0 - 1
    7 - 2010-05-05 14:50:22 - 0 - 1
    8 - 2010-05-05 14:59:22 - 1 - 1
    9 - 2010-05-05 16:31:22 - 0 - 1
    Voici le résultat que j'aimerais obtenir :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    'Date' - 'Valeur 1' - 'Valeur 2'
    2010-05-03 - 2 - 1
    2010-05-04 - 1 - 2
    2010-05-05 - 1 - 4
    Donc j'aimerais regrouper par date mes valeurs 1 et 2 et ensuite les additionnées.

    Voici ce que j'ai codé :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    SELECT
    [Date]
    ,SUM([Valeur 1]) as [Val1]
    ,SUM([Valeur 2]) as [Val2]
     
    FROM [Ma_Table]
     
    GROUP BY
    [Date]
    ,SUM([Valeur 1]) as [Val1]
    ,SUM([Valeur 2]) as [Val2]
    Le résultat n'est pas celui attendu.
    Quelqu'un aurait une idée ?

  2. #2
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Par défaut
    Bonjour,

    Si vous êtes sous SQL Server 2008, vous pouvez écrire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT	CAST(date AS date) AS date
    	, SUM(valeur1) AS val1
    	, SUM(valeur2) AS val2
    FROM	dbo.maTable
    GROUP	BY CAST(date AS date)
    ORDER	BY CAST(date AS date)
    Et pour toutes les versions :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT	CONVERT(char(10), date, 120) AS date
    	, SUM(valeur1) AS val1
    	, SUM(valeur2) AS val2
    FROM	dbo.maTable
    GROUP	BY CONVERT(char(10), date, 120)
    ORDER	BY CONVERT(char(10), date, 120)
    Néanmoins si vous recherchez de bonnes performances, vous pouvez peut-être ajouter une colonne calculée à votre table, qui vous extrait la date, et indexer celle-ci );

    @++

  3. #3
    Membre éclairé
    Inscrit en
    Mai 2008
    Messages
    298
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 298
    Par défaut
    C'est super, ça fonctionne parfaitement MERCI

    Par contre, il m'arrive de temps en temps que l'addition de valeur 1 et 2 soit à 0. et dans ce cas, la date ne s'affiche pas. (p.ex: 2010-08-06 - 0 - 0)

    Savez-vous comment je peux lui dire de m'afficher la date même si le résultat est = à 0?

  4. #4
    Membre éclairé
    Inscrit en
    Mai 2008
    Messages
    298
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 298
    Par défaut
    C'est tout bon.
    Merci

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

Discussions similaires

  1. selection avec group by mais ne garder que ...
    Par Larson dans le forum Langage SQL
    Réponses: 13
    Dernier message: 22/06/2005, 17h23
  2. [débutant] problème avec Group by
    Par Amenofis dans le forum Débuter
    Réponses: 5
    Dernier message: 25/05/2005, 09h57
  3. Prb. avec group by
    Par bianconeri dans le forum Langage SQL
    Réponses: 2
    Dernier message: 31/03/2005, 14h01
  4. requête avec group by
    Par Staron dans le forum Langage SQL
    Réponses: 4
    Dernier message: 29/11/2004, 16h30
  5. update avec group by
    Par slc dans le forum Requêtes
    Réponses: 4
    Dernier message: 05/10/2004, 13h44

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