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 :

Récupérer la somme de colonnes de plusieurs tables


Sujet :

Langage SQL

  1. #1
    Rédacteur
    Avatar de romaintaz
    Homme Profil pro
    Java craftsman
    Inscrit en
    Juillet 2005
    Messages
    3 790
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Java craftsman
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2005
    Messages : 3 790
    Points : 7 275
    Points
    7 275
    Par défaut Récupérer la somme de colonnes de plusieurs tables
    Bonjour,

    Je voudrais faire la somme de plusieurs colonnes sur 2 tables différentes (mais de structures identiques).
    Si je me restreint à une seule table, j'aurais quelque chose comme ça :

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    select MOIS_REF, SUM(Montant1), SUM(Montant2)
        from T_BIDULE
        where vendeur = XXX
        group by MOIS_REF;

    Je voudrais maintenant travailler aussi sur la table T_MACHINE, et donc avoir un select qui me retourne 3 colonnes :
    MOIS_REF
    SUM(T_BIDULE.Montant1) + SUM(T_MACHIN.Montant1)
    SUM(T_BIDULE.Montant2) + SUM(T_MACHIN.Montant2)
    le tout groupé par MOIS_REF.

    Comment puis-je faire cela au juste ?

    A noter qu'il se peut tout à fait qu'il y ait une entrée pour un MOIS_REF donné dans l'une des tables, mais pas dans l'autre. Dans ce cas, la ligne ne doit pas être ignorée (la somme totale sera donc la somme de la ligne renseignée + 0).

    (le but de ce select est d'être utilisé dans un insert sur une 3e table)

    ps : Ma BD est Oracle 10g.
    Nous sommes tous semblables, alors acceptons nos différences !
    --------------------------------------------------------------
    Liens : Blog | Page DVP | Twitter
    Articles : Hudson | Sonar | Outils de builds Java Maven 3 | Play! 1 | TeamCity| CitConf 2009
    Critiques : Apache Maven

  2. #2
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 031
    Points
    34 031
    Billets dans le blog
    14
    Par défaut
    Il faut joindre les deux tables pour pouvoir faire des calculs portant sur les deux dans la même requête.
    Le problème c'est qu'avec ton exemple trop abstrait on ne peut pas t'aider. Avec des bidules et des machins, impossible de deviner ce qui peut relier les deux tables.
    Donne-nous la structure de tes tables si tu veux qu'on t'aide.
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole. Autoentrepreneur.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

  3. #3
    Rédacteur
    Avatar de romaintaz
    Homme Profil pro
    Java craftsman
    Inscrit en
    Juillet 2005
    Messages
    3 790
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Java craftsman
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2005
    Messages : 3 790
    Points : 7 275
    Points
    7 275
    Par défaut
    Merci pour ta réponse.

    En fait j'ai fini par trouver une façon de réaliser ce que je voulais faire, en utilisant un UNION :

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    SELECT MOIS_REF, SUM(sommeMontant1), SUM(sommeMontant2)
    FROM (
    SELECT MoisAmo, SUM(montant1) as sommeMontant1,  SUM(montant2) as sommeMontant2
          FROM T_BIDULE
          WHERE vendeur = XXX
          GROUP BY MOIS_REF
      UNION ALL SELECT MoisAmo, SUM(montant1), SUM(montant2)
          FROM T_MACHIN
          WHERE vendeur = XXX
          GROUP BY MOIS_REF
      ) tmp
    GROUP BY MOIS_REF;

    Si toutefois une autre solution est envisageable, je suis prenneur.

    Pour répondre à ta question CinePhil, je ne sais pas si c'est vraiment utile de savoir ce qui relie les 2 tables non (je peux me tromper, hein ! ) ? Je veux dire par là que dans les 2 tables, j'ai des items (leur PK est une combinaison de 4 champs, dont vendeur et mois_ref) dont je veux sommer différents montants (les montant1, montant2 (et d'autres, que j'ai ignoré ici pour simplifier)) en les regroupant par les valeurs de mois_ref.

    Du coup, si j'ai (en sommant les montants dans les tables) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    MOIS_REF    sum(MONTANT_1)    sum(MONTANT_2)
    2009_01     a                 b
    2009_02     c                 (null)
    2009_03     d                 e
     
    MOIS_REF    sum(MONTANT_1)    sum(MONTANT_2)
    2009_01     g                 h
    2009_02     (null)            (null)
    2009_03     (null)            j
    je voudrais au final avoir les résultats suivants :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    MOIS_REF    sum(MONTANT_1)    sum(MONTANT_2)
    2009_01     a + g             b + h
    2009_02     c                 0
    2009_03     d                 e + j
    Voilà, j'espère que je suis un peu plus clair
    Nous sommes tous semblables, alors acceptons nos différences !
    --------------------------------------------------------------
    Liens : Blog | Page DVP | Twitter
    Articles : Hudson | Sonar | Outils de builds Java Maven 3 | Play! 1 | TeamCity| CitConf 2009
    Critiques : Apache Maven

  4. #4
    Rédacteur
    Avatar de romaintaz
    Homme Profil pro
    Java craftsman
    Inscrit en
    Juillet 2005
    Messages
    3 790
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Java craftsman
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2005
    Messages : 3 790
    Points : 7 275
    Points
    7 275
    Par défaut
    Une version simplifiée de la requête :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT tmp.MOIS_REF, SUM(tmp.montant1), SUM(tmp.montant2)     FROM (         SELECT MOIS_REF, montant1, montant2
                FROM T_BIDULE
                WHERE vendeur = XXX
            UNION ALL         SELECT MOIS_REF, montant1, montant2
                FROM T_MACHIN
                WHERE vendeur = XXX
        ) tmp
    GROUP BY tmp.MOIS_REF;
    Nous sommes tous semblables, alors acceptons nos différences !
    --------------------------------------------------------------
    Liens : Blog | Page DVP | Twitter
    Articles : Hudson | Sonar | Outils de builds Java Maven 3 | Play! 1 | TeamCity| CitConf 2009
    Critiques : Apache Maven

  5. #5
    Membre émérite Avatar de pacmann
    Homme Profil pro
    Consulté Oracle
    Inscrit en
    Juin 2004
    Messages
    1 626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Consulté Oracle
    Secteur : Distribution

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 626
    Points : 2 845
    Points
    2 845
    Par défaut
    Salut !

    Ta méthode est bonne.
    L'autre solution envisageable aurait été de faire la jointure FULL OUTER entre les deux group by.
    Mais franchement, ça n'apporte vraiment rien (que ce soit d'un point de vue performances, ou résultat)

    (c'est ma photo)
    Paku, Paku !
    Pour les jeunes incultes : non, je ne suis pas un pokémon...

    Le pacblog : http://pacmann.over-blog.com/

  6. #6
    Rédacteur
    Avatar de romaintaz
    Homme Profil pro
    Java craftsman
    Inscrit en
    Juillet 2005
    Messages
    3 790
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Java craftsman
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2005
    Messages : 3 790
    Points : 7 275
    Points
    7 275
    Par défaut
    Merci pour la précision.
    Je peux donc considérer ce problème comme résolu
    Nous sommes tous semblables, alors acceptons nos différences !
    --------------------------------------------------------------
    Liens : Blog | Page DVP | Twitter
    Articles : Hudson | Sonar | Outils de builds Java Maven 3 | Play! 1 | TeamCity| CitConf 2009
    Critiques : Apache Maven

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

Discussions similaires

  1. faire des sommes de colonnes de plusieurs tables
    Par davidovski dans le forum Requêtes
    Réponses: 3
    Dernier message: 31/08/2012, 12h12
  2. Réponses: 5
    Dernier message: 21/09/2009, 03h03
  3. Récupérer la valeur des colonnes d'une table
    Par amazing dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 22/07/2009, 17h27
  4. Copie de colonnes de plusieures tables dans une autre table
    Par PPLILH2008 dans le forum Modélisation
    Réponses: 3
    Dernier message: 04/06/2008, 15h09
  5. Réponses: 2
    Dernier message: 09/01/2006, 16h10

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