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 MySQL Discussion :

GROUP BY avec TABLES JOINTES


Sujet :

Requêtes MySQL

  1. #1
    Membre régulier
    Homme Profil pro
    Inscrit en
    Juin 2007
    Messages
    110
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 65
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 110
    Points : 73
    Points
    73
    Par défaut GROUP BY avec TABLES JOINTES
    Bonjour,

    Voici le cas de figure que je n'arrive pas à résoudre.
    Je désire faire la somme du champs 1 de la table 1 et la somme du champs 2 de la table 2 sachant que dans ma requête je joins les 2 tables.

    Voici mon code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    $requete = mysql_query('
      SELECT tab1.champs0, 
        SUM(champs1) as tot1,
        SUM(champs2) as tot2 
      FROM tab1 
      LEFT JOIN tab2 ON tab1.champs0 = tab2.champs0 
      GROUP BY tab1.champs0 '
    ) or die ("erreur requete synthese ".mysql_error());
    Avec ce code, le résultat est très surprenant.
    Je m'explique dans tab1 j'ai 4 enregistrements avec la même valeur de champs0
    (A) et les valeurs suivantes de champs1 100 / 150 / 110 / 40
    La somme devrait me faire 400 et cela me donne 1600 soit 4 fois plus.
    Il en est de même pour la somme de champs2 de la table 2 (multiplication par 4)

    Je vous remercie de votre aide.

  2. #2
    Membre régulier
    Homme Profil pro
    Inscrit en
    Juin 2007
    Messages
    110
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 65
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 110
    Points : 73
    Points
    73
    Par défaut
    A priori mon problème doit être plus important que je ne le pensais, ou peut-être qu'il ne faut pas l'aborder de cette manière. J'ajoute donc des infos sur tab1 et tab2 pour faciliter la compréhension:

    tab1 a 2 champs (champs0 et champs1) et les 4 enregistrements suivants
    A / 100
    A / 150
    A / 110
    A / 40

    tab2 a 2 champs (champs0 et champs2) et les 4 enregistrements suivants
    A / 50
    A / 50
    A / 100
    A / 80

    Au final tot1 = 1600 et tot2 = 1120

Discussions similaires

  1. Pagination avec table jointe et sous-requête
    Par dovmeup dans le forum Requêtes
    Réponses: 11
    Dernier message: 30/05/2014, 09h11
  2. Critère de requete avec table jointe
    Par Boid' dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 03/05/2013, 09h33
  3. Réponses: 11
    Dernier message: 20/11/2008, 18h08
  4. Réponses: 3
    Dernier message: 13/12/2006, 18h05
  5. Tables jointes, avec enregistrements multiples
    Par ARRG dans le forum Langage SQL
    Réponses: 3
    Dernier message: 14/07/2004, 14h00

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