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 :

question sur jointure


Sujet :

Requêtes MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Inscrit en
    Juin 2004
    Messages
    242
    Détails du profil
    Informations forums :
    Inscription : Juin 2004
    Messages : 242
    Par défaut question sur jointure
    Bonjour,

    je me pose une question qui parrait toute bête
    est ce que cest 2 requetes avec jointure vont me donner le même résultat

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SELECT COUNT(*) FROM notice n
    LEFT JOIN auteur  a ON n.ID_notice = a.ID_Notice AND a.Nom = 'Zola'
    WHERE n.Titre = 'germinal'
    ou

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SELECT COUNT(*) FROM notice n
    LEFT JOIN auteur  a ON n.ID_notice = a.ID_Notice 
    WHERE n.Titre = 'germinal' AND a.Nom = 'Zola'
    en fait, je voudrais savoir si je peux mettre indifférement ma condition sur l'auteur dans ma jointure ou dans le WHERE. Et si je ne peux pas, quel est la différence entre ces 2 requêtes.

    Merci d'avance

  2. #2
    Membre averti
    Inscrit en
    Avril 2007
    Messages
    42
    Détails du profil
    Informations forums :
    Inscription : Avril 2007
    Messages : 42
    Par défaut
    Pour moi, ça fait exactement la même chose mais je trouve plus jolie la deuxième méthode. Question de goût.

  3. #3
    Membre Expert
    Avatar de Sivrît
    Profil pro
    Inscrit en
    Février 2006
    Messages
    953
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Février 2006
    Messages : 953
    Par défaut
    Il y a une différence de taille : Le WHERE est appliqué après la jointure.

    La première version réalise une jointure plus restrictive. Comme c'est un "LEFT JOIN" (sans le LEFT ce serait équivalent), si on ne trouve pas Zola on obient une notice avec un auteur NULL qui sera retournée.

    La deuxième réalise une jointure plus permissive qui donne moins d'auteurs à NULL (si le cas se présente, sinon il ne fallait pas utiliser le 'LEFT JOIN' qui est plus lent) car dès qu'il y a au moins un auteur qui passe le critère du 'ON' le couple (notice, NULL) n'est plus ajouté. Ensuite on applique le "WHERE a.Nom = 'Zola'" qui ne laissera pas passer d'auteur à NULL contrairement à la première requête.

    Les résultats peuvent donc pas mal différer suivant les données présentes.

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

Discussions similaires

  1. Question sur la jointure avec MYSQL
    Par beegees dans le forum Requêtes
    Réponses: 2
    Dernier message: 05/10/2008, 09h05
  2. questions sur une jointure
    Par schub1015 dans le forum Langage SQL
    Réponses: 5
    Dernier message: 29/02/2008, 15h32
  3. Question sur les jointures
    Par richard038 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 02/06/2006, 11h46
  4. [MYSQL] Question sur jointure
    Par LE NEINDRE dans le forum Requêtes
    Réponses: 4
    Dernier message: 17/10/2005, 11h46
  5. select sur plusieurs table, question sur jointure
    Par Schulman dans le forum Langage SQL
    Réponses: 7
    Dernier message: 03/09/2004, 13h54

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