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 :

Jointure sur 2 tables dont l'une des 2 est vide


Sujet :

Requêtes MySQL

  1. #1
    Membre averti Avatar de renaud26
    Homme Profil pro
    Webmaster
    Inscrit en
    Mars 2003
    Messages
    1 365
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mars 2003
    Messages : 1 365
    Points : 436
    Points
    436
    Par défaut Jointure sur 2 tables dont l'une des 2 est vide
    Bonjour à tous,

    Soit une table "enfants" : id - prenom - nom

    Qui comporte 30 enregistrements.

    et une table "parents" id - prenom - nom -email - id_enfant

    Qui comporte 0 enregistrement (vide).

    Je voudrais afficher la liste des enfants et les prénoms, noms, emails de leur parents...sachant que les données parents seront garnies au fur et à mesure...mais qu'elles sont vides pour le moment. Donc si présence des données parents, je les affiche à côté de celles de leur enfant.

    Ma requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SELECT e.id, e.prenom as prenom_enfant, e.nom as nom_enfant, p.prenom as prenom_parent, p.nom as nom_parent, p.email 
    FROM enfants e, parents p 
    WHERE e.id = p.id_enfant order by e.nom
    Qui ne retourne évidemment rien, puisque une des 2 tables est vide.
    Mais, alors...comment faire ?
    Merci d'avance.

  2. #2
    Expert confirmé Avatar de Cybher
    Homme Profil pro
    Consultant réseaux et sécurité
    Inscrit en
    Mai 2005
    Messages
    3 281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Consultant réseaux et sécurité
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 281
    Points : 4 641
    Points
    4 641
    Par défaut
    salut,

    il faut dans ce cas passer par une jointure externe
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT e.id, e.prenom as prenom_enfant, e.nom as nom_enfant, p.prenom as prenom_parent, p.nom as nom_parent, p.email 
    FROM enfants e LEFT JOIN parents p 
    ON e.id = p.id_enfant 
    order by e.nom

  3. #3
    Membre averti Avatar de renaud26
    Homme Profil pro
    Webmaster
    Inscrit en
    Mars 2003
    Messages
    1 365
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mars 2003
    Messages : 1 365
    Points : 436
    Points
    436
    Par défaut
    Bonsoir et merci beaucoup, c'est impec !

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

Discussions similaires

  1. [MySQL] ajouter une ligne si une des colonnes est vide
    Par JibsouX dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 26/08/2013, 18h45
  2. Intégrale dont l'une des bornes est une variable
    Par clem3900 dans le forum MATLAB
    Réponses: 1
    Dernier message: 20/07/2012, 15h42
  3. une non equi-jointure sur deux tables
    Par AliJava dans le forum Langage SQL
    Réponses: 6
    Dernier message: 14/06/2008, 15h26
  4. Liste des tables dont dépend une autre
    Par katoyi dans le forum MS SQL Server
    Réponses: 6
    Dernier message: 28/05/2008, 18h53
  5. Réponses: 2
    Dernier message: 25/09/2006, 13h04

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