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 et SQL. Discussion :

Problème join requête SQL


Sujet :

Requêtes et SQL.

  1. #1
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2014
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Santé

    Informations forums :
    Inscription : Mars 2014
    Messages : 3
    Points : 4
    Points
    4
    Par défaut Problème join requête SQL
    Bonjour à tous,

    Je suis nouveau sur ce forum et je débute en SQL voilà pourquoi je viens vous solliciter pour une requête qui est peut être basique. J'ai essayé de me renseigner auprès des différents JOIN mais je n'ai pas trouvé la solution à mon problème.

    Je vous explique:

    J'ai une table 'droite' contenant des 'id' et j'ai besoin de faire correspondre à ces 'id' des 'num' qui sont dans ma table 'gauche'. Bien évidement dans ma table 'gauche' j'ai les 'id' qui correspondent à la table 'droite'. Cependant dans ma table 'gauche' j'ai plusieurs 'num' pour un même 'id' et je n'arrive pas à obtenir une table avec tous les 'num' pour chaque 'id'.

    J'arrive seulement à obtenir un 'num' pour chaque 'id' en utilisant INNER JOIN ou NATURAL JOIN, j'ai aussi essayé avec IN qui me donne la même chose.

    Pouvez vous m'aider à résoudre mon problème? N’hésitez pas à me demander plus d'informations.

    Bonne journée !
    Thomas

  2. #2
    Membre habitué
    Homme Profil pro
    Analyste développeur VB6, SQL, VB.NET, C#
    Inscrit en
    Avril 2003
    Messages
    111
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Analyste développeur VB6, SQL, VB.NET, C#
    Secteur : Bâtiment

    Informations forums :
    Inscription : Avril 2003
    Messages : 111
    Points : 141
    Points
    141
    Par défaut
    Bonjour et bienvenue,

    Je vous propose d'utiliser la jointure LEFT JOIN entre vos tables.
    Ce type de jointure permettra de récupérer toutes les informations de la table située à gauche de la jointure (autrement dit votre table 'gauche').

    Bonne continuation.

    Ld

  3. #3
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2014
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Santé

    Informations forums :
    Inscription : Mars 2014
    Messages : 3
    Points : 4
    Points
    4
    Par défaut
    Bonjour littledoudou et merci pour votre réponse,

    J'avais déjà essayé d'utiliser le LEFT JOIN cependant lorsque je fais ca la ligne en plus du résultat de la requête me donne quelque chose de curieux.

    mon id avec plusieurs num est 1 (les deux num sont 478 et 56677) :
    et le résultat est les suivant
    id num
    1 478
    ( d'autres données ...)
    478 56677

    Alors que j'aimerais avoir quelque chose du type:
    id num
    1 478
    1 56677
    ....

    Avez vous une idée?

  4. #4
    Membre habitué
    Homme Profil pro
    Analyste développeur VB6, SQL, VB.NET, C#
    Inscrit en
    Avril 2003
    Messages
    111
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Analyste développeur VB6, SQL, VB.NET, C#
    Secteur : Bâtiment

    Informations forums :
    Inscription : Avril 2003
    Messages : 111
    Points : 141
    Points
    141
    Par défaut
    Re,

    Autant pour moi, il s'agit dans votre cas de RIGHT JOIN (nous voulons tous les enregistrements de la 2e table liés à la 1ère)

    Nous devrions avoir une requête (simplifiée) qui ressemble à cela (je vais utiliser les noms de table gauche et droite):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT
    droite.id,
    gauche.num
    FROM
    droite
    RIGHT JOIN gauche ON droite.id = gauche.id
    ;
    Donc, au niveau du résultat, la première colonne est le champ droite.id et la deuxième le champ gauche.num correspondant à la jointure par le champ id des deux tables.

    Votre résultat
    semble indiquer que la table droite dispose d'un enregistrement avec un id à 478.
    Si cela est le cas, il est tout à fait normal de retrouver cette ligne.
    Dans le cas contraire, avez-vous mis le nom de la table devant le nom des champs (cela pourrait etre un mélange avec les champs id des deux tables)?

    Ld

  5. #5
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2014
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Santé

    Informations forums :
    Inscription : Mars 2014
    Messages : 3
    Points : 4
    Points
    4
    Par défaut
    Ca marche !
    Merci beaucoup pour votre aide

  6. #6
    Membre habitué
    Homme Profil pro
    Analyste développeur VB6, SQL, VB.NET, C#
    Inscrit en
    Avril 2003
    Messages
    111
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Analyste développeur VB6, SQL, VB.NET, C#
    Secteur : Bâtiment

    Informations forums :
    Inscription : Avril 2003
    Messages : 111
    Points : 141
    Points
    141
    Par défaut
    Content de vous avoir aiguillé pour résoudre votre soucis.
    Bonne continuation.

    N'oubliez pas de mettre votre sujet en "RÉSOLU".

    Ld

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

Discussions similaires

  1. Problème de requête SQL avec instruction TRANSFORM
    Par Nosper dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 21/06/2005, 16h15
  2. problème de requète SQL pour formulaire
    Par en_stage dans le forum Requêtes et SQL.
    Réponses: 15
    Dernier message: 21/06/2005, 12h21
  3. [SQL] Problème de requête SQL de plus de 8060 caractères ?
    Par webtheque dans le forum MS SQL Server
    Réponses: 13
    Dernier message: 06/04/2005, 15h07
  4. [SQLserver2000][SQLServer CE] problème de requête SQL
    Par JBernn dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 27/01/2005, 09h29
  5. Problème de requète SQL dans un Requery
    Par Keraccess dans le forum Requêtes et SQL.
    Réponses: 7
    Dernier message: 22/10/2004, 14h58

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