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 :

Grouper sur mois et année (seulement) d'une date


Sujet :

Langage SQL

  1. #1
    Membre confirmé Avatar de Claythest
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    558
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 558
    Points : 554
    Points
    554
    Par défaut Grouper sur mois et année (seulement) d'une date
    Bonjour,

    J'ai une table avec une colonne de type Date D, et une autre de type nombre N.

    Je souhaiterai avoir la somme des N groupée sur les mois et année de la date D...

    En gros, je voudrais écrire une requête de la sorte :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT YEAR(D), MONTH(D), SUM(N)
    FROM MATABLE
    GROUP BY YEAR(D), MONTH(D)
    Est-ce possible, ou suis-je obligé (car j'en ai peut être la possibilité), de splitter ma colonne DATE en 3 colonnes pour le jour, le mois et l'année ?

    Si ma question n'est pas assez claire, n'hésitez pas à me demander des précisions

    Merci d'avance

    P.S. : J'utilise le SGBD derby, les fonctions YEAR() et MONTH() renvoient respectivement l'année et le mois de la date passée en paramètre...

  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 802
    Points
    30 802
    Par défaut
    Conceptuellement, cette requête est tout à fait valide.
    Après, je ne connais pas Derby et ses limites...
    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 confirmé Avatar de Claythest
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    558
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 558
    Points : 554
    Points
    554
    Par défaut
    Ok,
    ce qui veut dire que cette requête (en changeant les fonctions par leurs équivalentes) fonctionnerait sur un autre SGBD ? Parce que en effet, sous derby, ca ne passe pas... il me sort l'erreur suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Error code -1, SQL state 42X01: Syntax error: Encountered "YEAR" at line 3, column 10.
    en gros, il n'a pas l'air content que je veuille utiliser une fonction dans mon group by... J'ai donc testé avec un renommage :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT YEAR(D) AS Y, MONTH(D) AS M, SUM(N)
    FROM MATABLE
    GROUP BY Y,M
    ... mais je me prend alors l'erreur suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Error code -1, SQL state 42X04: Column 'Y' is either not in any table in the FROM list or appears within a join specification and is outside the scope of the join specification or appears in a HAVING clause and is not in the GROUP BY list. If this is a CREATE or ALTER TABLE  statement then 'Y' is not a column in the target table.
    bref, je ne sais comment m'y prendre, et j'ignore si je respecte bien la norme SQL en voulant faire une requête de ce genre, ou si c'est derby qui m'en empêche...

    Merci en tout cas pour ta participation

  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 802
    Points
    30 802
    Par défaut
    Une syntaxe qui est aussi acceptée par certains SGBD est :
    La norme n'interdit pas l'usage de fonctions ou d'alias de colonnes...
    D'où mes réserves quant aux limites du SGBD, aucun des SGBD que j'ai utilisé à ce jour n'implémentant l'intégralité de la norme
    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 confirmé Avatar de Claythest
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    558
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 558
    Points : 554
    Points
    554
    Par défaut
    ok merci pour ces infos

    Il n'est pas friand de mon "1, 2" non plus

    Bon, je vais voir, soit changer de SGBD, soit splitter mes colonnes...

    Merci beaucoup pour ton aide

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

Discussions similaires

  1. Extraire mois et année à partir d'une date
    Par jikharti dans le forum QlikView
    Réponses: 1
    Dernier message: 10/01/2014, 12h13
  2. [2008R2] Afficher moi et année à partir d'une date
    Par miniil dans le forum Développement
    Réponses: 1
    Dernier message: 17/06/2013, 15h56
  3. [XL-2003] Récupérer jour, mois et année à partir d'une date
    Par adamsmith dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 24/08/2009, 17h11
  4. Primary Key sur mois et année d'une date
    Par Somato dans le forum SQLite
    Réponses: 4
    Dernier message: 19/06/2008, 17h57
  5. [tmap] extraire mois, année etc d'une date
    Par ben_harper dans le forum Développement de jobs
    Réponses: 2
    Dernier message: 24/04/2008, 11h07

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