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 :

Problème SQL INNER JOIN


Sujet :

Langage SQL

  1. #1
    Membre averti
    Homme Profil pro
    Développeur Web
    Inscrit en
    Janvier 2008
    Messages
    519
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Janvier 2008
    Messages : 519
    Points : 311
    Points
    311
    Par défaut Problème SQL INNER JOIN
    Salut,

    Soit la requête suivante permettant de calculer le nombre de messages postés par les membres :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT membre.id AS id, membre.pseudo AS pseudo, membre.last_connection AS last_connection, COUNT(forum_message.id) AS nb_message FROM membre INNER JOIN forum_message ON membre.id = forum_message.auteur WHERE membre.classe=$classe_membre GROUP BY membre.id
    Le problème est le suivant :

    La requête affiche uniquement les membres ayant posté au moins 1 message sur le forum, je voudrais pouvoir afficher les membres ayant posté aucun message.

    Merci

  2. #2
    Membre régulier
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2007
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2007
    Messages : 43
    Points : 73
    Points
    73
    Par défaut
    La jointure interne ne garde que les lignes de la table de gauche qui ont une correspondance dans la table de droite! Si tu veux un résultat avec tous les membres(toutes les lignes de la table membres) qu'ils aient postés des messages ou non (qu'ils aient ou non une correspondance dans la table forum_message) il faut utiliser une jointure externe.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    SELECT 	membre.id AS id,
    	membre.pseudo AS pseudo, 
    	membre.last_connection AS last_connection, 
    	COUNT(forum_message.id) AS nb_message 
    FROM membre 
    	LEFT OUTER JOIN forum_message ON membre.id = forum_message.auteur 
    WHERE membre.classe=$classe_membre 
    GROUP BY membre.id

  3. #3
    Membre averti
    Homme Profil pro
    Développeur Web
    Inscrit en
    Janvier 2008
    Messages
    519
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Janvier 2008
    Messages : 519
    Points : 311
    Points
    311
    Par défaut
    Ok, c'est compris

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

Discussions similaires

  1. SQL inner join select temps d'éxécution
    Par binouzzz19 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 23/10/2007, 15h50
  2. Probleme de SQL INNER JOIN WHERE
    Par korben06 dans le forum Langage SQL
    Réponses: 1
    Dernier message: 05/06/2007, 19h18
  3. problème requete inner join
    Par maysa dans le forum Langage SQL
    Réponses: 4
    Dernier message: 24/04/2007, 13h48
  4. [Oracle] problème avec INNER JOIN
    Par Philofish dans le forum Langage SQL
    Réponses: 5
    Dernier message: 15/09/2005, 11h20
  5. [ requeste sql ]INNER JOIN / OUTER JOIN
    Par hocinema dans le forum Langage SQL
    Réponses: 2
    Dernier message: 12/04/2004, 22h28

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