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 :

Requête avec jointures


Sujet :

Langage SQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    134
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 134
    Par défaut Requête avec jointures
    Bonjour à tous
    Je consulte le manuel SQL de A à Z mais y a des choses que je ne comprends pas trop sur la jointure en fait je ne comprends pas les differences entre les jointures.


    les tables

    demandeprix : clé primaire id_demandeprix clé externe id_users id_affaire
    users : clé primaire id_users
    affaire : clé primaire id_affaire
    fournisseurs : clé primaire id_fournisseurs

    Dans un premier temps je selectionne les demandes de prix en fonction d'un fournisseur :

    Donc je fais :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT demandeprix.*  FROM demandeprix WHERE id_fournisseur = $id_fournisseur
    jusque la tout va bien mais quand je veux recuperer le nom du founisseur , le nom de l'affaire , et l utilisateur sa foire totalement :

    Je modifie ma requete du dessus pour l'adapter .

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT demandeprix.*, users.*, fournisseurs.* FROM demandeprix, users, fournisseurs 
    WHERE demandeprix.id_users = users.id_users 
             AND demandeprix.id_affaire = affaire.id_affaire 
                AND id_fournisseur = $id_fournisseur
    J'ai essayé ca aussi mais sans succés :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT demandeprix.*, users.*, fournisseurs.* FROM demandeprix, users, fournisseurs 
    JOIN ON demandeprix.id_users = users.id_users 
       AND demandeprix.id_affaire = affaire.id_affaire 
          WHERE id_fournisseur = $id_fournisseur
    Merci à tous
    Cordialement
    Bypbop

  2. #2
    Membre confirmé
    Inscrit en
    Juin 2004
    Messages
    66
    Détails du profil
    Informations forums :
    Inscription : Juin 2004
    Messages : 66
    Par défaut Re: Requête avec jointures
    Salut,
    je pense qu'il te manque une jointure

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT demandeprix.*, users.*, fournisseurs.* FROM demandeprix, users, fournisseurs, affaire
    WHERE demandeprix.id_users = users.id_users 
             AND demandeprix.id_affaire = affaire.id_affaire 
             AND fournisseur.id_fournisseur = affaire.id_fournisseur 
                AND id_fournisseur = $id_fournisseur
    A+
    Chris

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    134
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 134
    Par défaut
    Re merci de ton aide

    mais je n'ai pas de champs id_fournisseur dans ma table affaire.

    Je mexplique un peu plus : dans ma table demandeprix je stocke toutes les demande de prix. dans cette table il y a un champs id_users et id_affaire ainsi que l'id_fournisseur .

    Moi je veux lister toutes les demandes de prix en fonction d'un certain fournisseur d'ou le $fournisseur .
    jusque la tt va bien mais j'aimerais ajouter le nom de l'affaire et l'utilisateur qui a créer la demande de prix et la je bug avec les jointures.

    Meric bcp pour votre aide
    cordialement
    corben

  4. #4
    Membre expérimenté
    Inscrit en
    Février 2003
    Messages
    182
    Détails du profil
    Informations forums :
    Inscription : Février 2003
    Messages : 182
    Par défaut
    essaies ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SELECT demandeprix.*, users.*, 
    (Select fournisseurs.*
    from  fournisseurs
    Where  id_fournisseur = $id_fournisseur)
    FROM demandeprix, users,  affaire 
    WHERE demandeprix.id_users = users.id_users 
     AND demandeprix.id_affaire = affaire.id_affaire

    A+

  5. #5
    Membre confirmé
    Inscrit en
    Juin 2004
    Messages
    66
    Détails du profil
    Informations forums :
    Inscription : Juin 2004
    Messages : 66
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT demandeprix.*, users.*, fournisseurs.* FROM demandeprix, users, fournisseurs, affaire 
    WHERE demandeprix.id_users = users.id_users 
             AND demandeprix.id_affaire = affaire.id_affaire 
             AND fournisseur.id_fournisseur = demandeprix.id_fournisseur 
                AND id_fournisseur = $id_fournisseur

    A+

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

Discussions similaires

  1. Requête avec jointure externe
    Par claralavraie dans le forum Langage SQL
    Réponses: 8
    Dernier message: 02/02/2006, 08h34
  2. Requête avec jointure
    Par Maglight dans le forum Langage SQL
    Réponses: 4
    Dernier message: 17/11/2005, 09h57
  3. optimisation d'une requête avec jointure
    Par champijulie dans le forum PostgreSQL
    Réponses: 8
    Dernier message: 07/07/2005, 09h45
  4. Mise à jour de table impossible après requête avec jointure
    Par sto dans le forum Bases de données
    Réponses: 5
    Dernier message: 17/03/2004, 13h24
  5. problème de requête avec jointures
    Par tinhat dans le forum Requêtes
    Réponses: 7
    Dernier message: 11/08/2003, 10h33

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