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

Langage SQL Discussion :

Requête pour avoir des totaux par mois


Sujet :

Langage SQL

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Février 2007
    Messages
    330
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 330
    Points : 145
    Points
    145
    Par défaut Requête pour avoir des totaux par mois
    Je croyais avoir compris mais j'ai l'impression qu'il me manque encore pas mal de chose ..
    La base est sous mysql
    J'ai une table contenant (pour simplifier) :
    - date
    - nom
    - ca

    je souhaite avoir le cumul des ca par mois

    je pensais que cette requête me donnerait le bon résultat :

    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
    18
    19
     
    SELECT nom,
    case when MONTH(date)=1 then SUM(ca) ELSE 0 END AS m01,
    case when MONTH(date)=2 then SUM(ca) ELSE 0 END AS m02,
    case when MONTH(date)=3 then sum(ca) ELSE 0 END AS m03,
    case when MONTH(date)=4 then sum(ca) ELSE 0 END AS m04,
    case when MONTH(date)=5 then sum(ca) ELSE 0 END AS m05,
    case when MONTH(date)=6 then sum(ca) ELSE 0 END AS m06,
    case when MONTH(date)=7 then sum(ca) ELSE 0 END AS m07,
    case when MONTH(date)=8 then sum(ca) ELSE 0 END AS m08,
    case when MONTH(date)=9 then sum(ca) ELSE 0 END AS m09,
    case when MONTH(date)=10 then sum(ca) ELSE 0 END AS m10,
    case when MONTH(date)=11 then sum(ca) ELSE 0 END AS m11,
    case when MONTH(date)=12 then sum(ca) ELSE 0 END AS m12
    from table
    WHERE
    (date>='2020-01-01')
    and (date<='2020-12-31')
    GROUP BY nom;
    J'ai bien la colonne nom et une colonne par mois,

    mais seule la colonne de janvier est remplie, et encore, pas avec les bons chiffres ... toutes les autres colonnes sont à 0 ... alors qu'il y a des chiffres pour tous les mois

    Merci de votre aide.

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 080
    Points : 30 778
    Points
    30 778
    Par défaut
    Bonjour,

    En fait, la condition n'est pas tout à fait posée comme il faudrait

    Comme cela, ça devrait fonctionner mieux :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     SUM(case when MONTH(date)=1 then ca ELSE 0 END) AS m01
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Février 2007
    Messages
    330
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 330
    Points : 145
    Points
    145
    Par défaut
    Merci beaucoup !

    Je dois dire que je m'arrachais les cheveux car j'étais persuadé d'avoir la bonne syntaxe, et malgré toutes mes recherches, je n'ai rien retrouvé sur le forum alors que je suis sûr d'avoir vu ça une fois ...

    Ca marche nickel maintenant !

  4. #4
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 080
    Points : 30 778
    Points
    30 778
    Par défaut
    Si tu as une version de MySQL récente, regarde du côté du PIVOT qui est la définition exacte de ce que tu fais dans ta requête.
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Février 2007
    Messages
    330
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 330
    Points : 145
    Points
    145
    Par défaut
    Je croyais que pivot n'existait pas dans mysql ?
    Dans mysql 8 il n'y a pas cette fonction ...
    En fait je suis en mariadb 10 qui doit être équivalent à mysql8

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

Discussions similaires

  1. Réponses: 16
    Dernier message: 04/02/2021, 18h17
  2. [KSH] Script pour trier des fichier dans des répertoires par mois
    Par MsieurDams dans le forum Shell et commandes GNU
    Réponses: 4
    Dernier message: 08/08/2014, 15h32
  3. Réponses: 1
    Dernier message: 06/09/2011, 15h26
  4. requête pour avoir min/max par intervales
    Par MASSAKA dans le forum Langage SQL
    Réponses: 2
    Dernier message: 28/06/2010, 19h41
  5. Réponses: 3
    Dernier message: 27/07/2004, 13h01

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