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] - Liaison sur plusieurs tables sur un même champ


Sujet :

PHP & Base de données

  1. #1
    Membre à l'essai
    Inscrit en
    Mai 2002
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 27
    Points : 23
    Points
    23
    Par défaut [SQL] - Liaison sur plusieurs tables sur un même champ
    Bonjour,

    Je dois faire une requête sur une base de données que l'on me donne et je ne sais pas comment m'y prendre. En effet, dans ma base de données je souhaite aller chercher pour un même champ dans 4 tables différentes suivant autre champs

    Je m'explique

    - - - Ma table principale - - -
    ID - origine - N°origine
    1 - C - 1
    2 - F - 1
    3 - C - 2

    - - - Ma table Client- - -
    ID - Libellé
    1 - ClientA
    2 - ClientB


    - - - Ma table Fournisseur- - -
    ID - Libellé
    1 - FournisseurA
    2 - FournisseurB

    Le but est que si dans ma table principale Origine = C alors je vais cherché le libellé dans ma Table Client et Origine = F dans la table Fournisseur


    j'aurais donc
    - - - Résultat attendu - - -
    ID - origine - N°origine - Libellé
    1 - C - 1 - ClientA
    2 - F - 1 - FournisseurA
    3 - C - 2 - ClientB

    J'espère que je suis clair ; sachant que l'objectif est d'aller chercher des prix dans les tables annexes pour faire des calculs.

    Merci à vous

    bonne soirée

  2. #2
    Membre éclairé Avatar de Geoffrey74
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2007
    Messages
    515
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2007
    Messages : 515
    Points : 760
    Points
    760
    Par défaut
    Salut,

    quel est le lien entre toutes ces tables ? Est ce qu'il y a une clé qui les relies entre elles ?
    Je n'en vois aucune dans ton message...

  3. #3
    Responsable Systèmes


    Homme Profil pro
    Gestion de parcs informatique
    Inscrit en
    Août 2011
    Messages
    17 354
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Gestion de parcs informatique
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Août 2011
    Messages : 17 354
    Points : 42 828
    Points
    42 828
    Par défaut
    Il te faut faire des jointures :
    http://sqlpro.developpez.com/cours/sqlaz/jointures/
    Ma page sur developpez.com : http://chrtophe.developpez.com/ (avec mes articles)
    Mon article sur le P2V, mon article sur le cloud
    Consultez nos FAQ : Windows, Linux, Virtualisation

  4. #4
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 947
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 947
    Points : 5 846
    Points
    5 846
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    select p.id, p.origine, p.num_origine
         , case when p.origine = 'C' then c.libelle 
                when p.origine = 'F' then f.libelle 
            end as libelle
      from principale p
      left join Client c 
        on c.id = p.num_origine
       and p.origine = 'C'
      left join Fournisseur f 
        on f.id = p.num_origine
       and p.origine = 'F'
     order by p.id

Discussions similaires

  1. [MySQL-5.6] Select sur plusieurs tables avec le même préfixe
    Par Bruno.F dans le forum Requêtes
    Réponses: 10
    Dernier message: 27/05/2016, 17h03
  2. Réponses: 9
    Dernier message: 19/04/2009, 16h45
  3. Réponses: 1
    Dernier message: 14/05/2007, 16h46
  4. Requete sur plusieurs tables contenant les mêmes champs
    Par Louison dans le forum Langage SQL
    Réponses: 3
    Dernier message: 03/04/2007, 21h41
  5. update table sur plusieurs tables
    Par jojolepabo dans le forum SQL
    Réponses: 5
    Dernier message: 08/02/2007, 18h22

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