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 :

[MySQL] Condition en plus d'un RIGHT JOIN


Sujet :

Langage SQL

  1. #1
    Membre habitué
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2003
    Messages
    120
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2003
    Messages : 120
    Points : 126
    Points
    126
    Par défaut [MySQL] Condition en plus d'un RIGHT JOIN
    Je ne parviens pas à sélectionner ce que je veux
    Si qq pouvait me donner un coup de main...

    Structure des Tables:
    Table revendeur
    idrevendeur
    nom
    ...
    Table rvd_echange
    idrvd_echange
    temps
    date
    #idrevendeur
    ...
    A des fin statistique je cherche à calculer combien d'echange on eu lieu avec un revendeur et combien de temps cela a durer (si aucun echange n'a eu lieu, je veux le voir aussi, d'où le RIGHT JOIN) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT revendeur.idrevendeur, nom, SUM(temps) AS time, COUNT(rvd_echange.idrevendeur) AS call FROM rvd_echange RIGHT JOIN revendeur USING(idrevendeur)  GROUP BY idrevendeur ORDER  BY nom
    Ca pas de problème, mais dès que je veux gerer ça par mois, c'est plus complexe et c'est là que je bloque
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT revendeur.idrevendeur, nom, SUM(temps) AS time, COUNT(rvd_echange.idrevendeur) AS call FROM rvd_echange RIGHT JOIN revendeur USING(idrevendeur) WHERE jour LIKE "'.$workYear.'-'.$workMonth.'-__ __:__:__" GROUP BY idrevendeur ORDER  BY nom
    Les revendeur avec qui il n'y a eu aucun echange n'apparaissent plus alors que je voudrait aussi le faire resortir

    Suis-je assez clair ? Y'a t'il une solution ?

  2. #2
    Inactif   Avatar de Médiat
    Inscrit en
    Décembre 2003
    Messages
    1 946
    Détails du profil
    Informations forums :
    Inscription : Décembre 2003
    Messages : 1 946
    Points : 2 227
    Points
    2 227
    Par défaut
    Essaye :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT r.idrevendeur, nom, SUM(temps) AS time, COUNT(re.idrevendeur) AS call 
    FROM rvd_echange re RIGHT JOIN revendeur r ON r.idrevendeur = re.idrevendeur AND jour LIKE "'.$workYear.'-'.$workMonth.'-__ __:__:__" 
    GROUP BY r.idrevendeur 
    ORDER  BY nom
    Sinon

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT revendeur.idrevendeur, nom, SUM(temps) AS time, COUNT(rvd_echange.idrevendeur) AS call 
    FROM rvd_echange RIGHT JOIN revendeur USING (idrevendeur)
    WHERE (jour LIKE "'.$workYear.'-'.$workMonth.'-__ __:__:__" 
      OR jour IS NULL)
    GROUP BY idrevendeur 
    ORDER  BY nom
    J'affirme péremptoirement que toute affirmation péremptoire est fausse
    5ième élément : barde-prince des figures de style, duc de la synecdoque
    Je ne réponds jamais aux questions techniques par MP

  3. #3
    Membre habitué
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2003
    Messages
    120
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2003
    Messages : 120
    Points : 126
    Points
    126
    Par défaut
    Citation Envoyé par Médiat
    Essaye :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT r.idrevendeur, nom, SUM(temps) AS time, COUNT(re.idrevendeur) AS call 
    FROM rvd_echange re RIGHT JOIN revendeur r ON r.idrevendeur = re.idrevendeur AND jour LIKE "'.$workYear.'-'.$workMonth.'-__ __:__:__" 
    GROUP BY r.idrevendeur 
    ORDER  BY nom
    Fonctionne à merveille
    Merci!

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

Discussions similaires

  1. MySQL ne répond plus ...
    Par Ickou dans le forum Outils
    Réponses: 19
    Dernier message: 10/05/2006, 18h01
  2. [MySQL 4.0.17] utilisation de LEFT JOIN 2 fois
    Par Zen_Fou dans le forum Administration
    Réponses: 4
    Dernier message: 26/04/2006, 13h55
  3. [MySQL] Trouve le plus petit identifiant libre
    Par Zapan dans le forum Langage SQL
    Réponses: 1
    Dernier message: 15/03/2006, 16h21
  4. Réponses: 4
    Dernier message: 28/10/2005, 20h58
  5. [MYSQL] conditions et requetes
    Par sebos63 dans le forum SQL Procédural
    Réponses: 3
    Dernier message: 26/02/2004, 16h41

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