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

Requêtes et SQL. Discussion :

Regroupement de données par date [AC-2010]


Sujet :

Requêtes et SQL.

  1. #1
    Expert confirmé Avatar de illight
    Homme Profil pro
    Analyste décisionnel
    Inscrit en
    Septembre 2005
    Messages
    2 342
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Analyste décisionnel
    Secteur : Service public

    Informations forums :
    Inscription : Septembre 2005
    Messages : 2 342
    Points : 4 299
    Points
    4 299
    Par défaut Regroupement de données par date
    Bonjour,


    j'ai 2 requêtes, une nommée test_recus, et l'autre test_traites.

    Dans ces 2 requêtes, j'ai à chaque fois 2 champs :
    - la date
    ET :
    - dans l'une le nombre de reçus
    - dans l'autre requête, le nombre de traités

    Du coup, dans ma requête test_recus, j'ai une ligne par date ; et dans ma requête test_traites, je n'ai pas forcément une ligne par date, mais j'ai quelques données.

    Je voudrais effectuer une requête, qui prend appui sur ces 2 requêtes (ou pas ?) qui me sorte une ligne par date avec le nombre de reçus et le nombre de traités, si cela existe bien évidemment.

    Pour cela, j'ai effectué la requête suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SELECT test_recus.Date, Sum(test_recus.recus) AS SommeDerecus, Sum(test_traites.Traites) AS SommeDeTraites
    FROM test_recus LEFT JOIN test_traites ON test_recus.Date = test_traites.Date
    GROUP BY test_recus.Date;
    Quand j'essaye de voir les données, ça me dit "opération non valide" et j'arrive pas à comprendre pourquoi.

    Par curiosité, et pour essayer de comprendre le pourquoi du comment, j'ai essayé la jointure interne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT test_recus.Date, Sum(test_recus.recus) AS SommeDerecus, Sum(test_traites.Traites) AS SommeDeTraites
    FROM test_recus INNER JOIN test_traites ON test_recus.Date = test_traites.Date
    GROUP BY test_recus.Date;
    Ça me sort bien un résultat, par contre je n'ai que les dates où j'ai des informations dans la requête des traités. Or je veux toutes les dates de ma requête sur les reçus, d'où ma jointure externe que j'ai essayé, en vain.

    Je ne sais pas si cela peux vous aider, mais ces 2 requêtes pointent sur une table oà j'ai, entre autre, une colonne date, des ID et une colonne traité qui est à VRAI ou FAUX suivant le cas. Au départ, j'était partie sur l'idée d'avoir mon résultat directement de cette table, mais je n'y arrivais pas, du coup je suis partie sur l'idées de ces sous-requêtes, mais malheureusement sans résultat

    Quelqu'un pourrait m'aiguiller sur une réponse qui répondrait à ce que je souhaite comme résultat ?

    En vous remerciant par avance de vos réponses

  2. #2
    Membre éclairé Avatar de dumas.blr
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juin 2010
    Messages
    598
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Conseil

    Informations forums :
    Inscription : Juin 2010
    Messages : 598
    Points : 879
    Points
    879
    Par défaut
    Bonjour illight,

    Le problème vient probablement de l'instruction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sum(test_traites.Traites) AS SommeDeTraites
    En effet, si tu fait une jointure externe, tu vas vouloir agréger des valeurs potentiellement nulles.

    Je pense que la solution passe par une fonction NZ pour forcer à zéro les valeurs nulles; quitte à faire l'opération en 2 temps
    1. faire la jointure externe et valoriser les valeurs nulles
    2. faire l'agrégation

  3. #3
    Expert confirmé Avatar de illight
    Homme Profil pro
    Analyste décisionnel
    Inscrit en
    Septembre 2005
    Messages
    2 342
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Analyste décisionnel
    Secteur : Service public

    Informations forums :
    Inscription : Septembre 2005
    Messages : 2 342
    Points : 4 299
    Points
    4 299
    Par défaut
    J'y ai pensé, mais je pensais pas que ça viendrait de là.

    Par contre, j'ai toujours le même message. Voici la requête modifiée :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SELECT test_recus.Date, Sum(test_recus.recus) AS SommeDerecus, Sum(Nz([Traites],0)) AS Expr1
    FROM test_recus LEFT JOIN test_traites ON test_recus.Date = test_traites.Date
    GROUP BY test_recus.Date;
    En fait, en écrivant, j'ai modifié ma requête test_traites, et rajouté la fonction NZ aussi pour le comptage, et du coup ça a marché

    Merci

    Décidément, ces valeurs nulles m'embêtent

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

Discussions similaires

  1. [XSLT] Regrouper des données par date
    Par sofuzion dans le forum XSL/XSLT/XPATH
    Réponses: 1
    Dernier message: 19/02/2009, 11h07
  2. Regroupement des données par catégorie
    Par Niagala dans le forum Excel
    Réponses: 3
    Dernier message: 07/11/2007, 10h19
  3. Trier les données par date au format jour mois année...
    Par ouskel'n'or dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 30/08/2007, 11h41
  4. Regrouper les données par rapport à la date
    Par goldeagle dans le forum Access
    Réponses: 7
    Dernier message: 11/12/2006, 15h35
  5. Extraire données par date du jour
    Par Hombe dans le forum Oracle
    Réponses: 6
    Dernier message: 08/11/2006, 11h14

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