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

PHP & Base de données Discussion :

[SQL] Lier 3 tables d'une base de données [Fait]


Sujet :

PHP & Base de données

  1. #1
    Membre averti
    Inscrit en
    Octobre 2007
    Messages
    22
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 22
    Par défaut [SQL] Lier 3 tables d'une base de données
    Bonjour, voilà en gros comment fonctionne cette base de donnée:

    entreprise
    - entreprises_id
    - Nom
    - adresse

    mots_clefs
    - mots_clefs_id
    - mot

    mots_entreprises
    - Clé
    - entreprises_id
    - mots_clefs_id


    Le but etant d'afficher pour chaque entreprises ses mots clefs, mais j'aimerai pouvoir le faire avec seulement une seule requete est-ce possible ?

    merci
    Cordialement

    Archalia

  2. #2
    Membre éclairé
    Homme Profil pro
    Consultant ERP
    Inscrit en
    Mai 2006
    Messages
    257
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Consultant ERP
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2006
    Messages : 257
    Par défaut
    Bonjour, Pour lier les tables vous devez utiliser les jointures. Voici un cour dessus http://sql.developpez.com/sqlaz/jointures/. Et pour votre requête je crois que ça va fonctionner comme ça:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    SELECT entreprise.nom, mots_clefs.mot
    FROM entreprise
    INNER JOIN mots_entreprises USING(entreprises_id)
    INNER JOIN mots_clefs USING(mots_clefs_id)
    Ce n'est qu'une suggestion à vous de créer votre requête par ce que je ne sais pas est ce que ça va marcher ou non.

  3. #3
    Membre Expert

    Homme Profil pro
    SDE
    Inscrit en
    Août 2007
    Messages
    2 013
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : SDE

    Informations forums :
    Inscription : Août 2007
    Messages : 2 013
    Par défaut
    mots_entreprises
    - Clé
    - entreprises_id
    - mots_clefs_id
    Si j'ai bien compris Clé dans cette table est inutile, puisque l'identifiant sera entreprises_id et a la fois mots_clefs_id.

    Ensuite comme le dit othmane126 tu dois faire une jointure, mais pour l'exemple moi j'ai plus tendence a utiliser une autre manière de faire une jointure qui est la suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT entreprise.nom, mots_clefs.mot
    FROM entreprise, mots_entreprise, mots_clefs
    WHERE entreprise.entreprises_id = mots_entreprise.entreprises_id
    AND mots_clefs.mots_clefs_id = mots_entreprise.mots_clefs_id
    GROUP BY entreprise.nom
    Le group by permet de regrouper tes mots clé par sur un critère (ici le nom de l'entreprise)

Discussions similaires

  1. Réponses: 6
    Dernier message: 08/12/2013, 09h25
  2. [AC-2002] Lier une table d'une base de données d'un groupe de travail différent
    Par waici dans le forum Modélisation
    Réponses: 1
    Dernier message: 22/05/2012, 10h02
  3. Réponses: 2
    Dernier message: 26/07/2011, 16h49
  4. Réponses: 2
    Dernier message: 03/11/2008, 07h33
  5. Lier un table dans une base sécurisée ?
    Par marot_r dans le forum Access
    Réponses: 7
    Dernier message: 04/07/2006, 19h09

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