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 :

Requête basique avec jointure qui retourne rien [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 486
    Billets dans le blog
    1
    Par défaut Requête basique avec jointure qui retourne rien
    Bonjour,
    voici une requête basique avec une jointure qui référence une seconde table mais dont la réponse est vide

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT US.US_firstname,US.US_lastname,US.US_sesa FROM LI_license LI
    JOIN US_user US ON LI.US_ident = US.US_ident
    JOIN usl_user_license USL ON USL.US_ident=US.US_ident
    WHERE US.US_sesa = '1'

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    CREATE TABLE US_user(
       US_ident INT UNSIGNED AUTO_INCREMENT,
       US_sesa INT,
       US_firstname VARCHAR(50),
       US_lastname VARCHAR(50),
       PRIMARY KEY(US_ident),
       UNIQUE(US_sesa)
    );
     
    CREATE TABLE USL_user_license(
       US_ident INT UNSIGNED,
       US_ident_manager INT UNSIGNED,
       COU_ident INT UNSIGNED,
       LO_ident INT UNSIGNED,
       CO_ident INT UNSIGNED NOT NULL,
       PRIMARY KEY(US_ident),
       FOREIGN KEY(US_ident) REFERENCES US_user(US_ident),
       FOREIGN KEY(US_ident_manager) REFERENCES USL_user_license(US_ident),
       FOREIGN KEY(COU_ident, LO_ident) REFERENCES LO_location(COU_ident, LO_ident),
       FOREIGN KEY(CO_ident) REFERENCES CO_company(CO_ident)
    );
     
    CREATE TABLE LI_license(
       LI_ident INT UNSIGNED AUTO_INCREMENT,
       LI_activate_date DATE NOT NULL,
       LI_deactivate_date DATE,
       AP_ident INT UNSIGNED NOT NULL,
       US_ident INT UNSIGNED NOT NULL,
       PRIMARY KEY(LI_ident),
       FOREIGN KEY(AP_ident) REFERENCES AP_application(AP_ident),
       FOREIGN KEY(US_ident) REFERENCES USL_user_license(US_ident)
    );

    A mon sens, on peut simplifier la requête en :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT US.US_firstname,US.US_lastname,US.US_sesa FROM LI_license LI
    JOIN US_user US ON LI.US_ident = US.US_ident
    WHERE US.US_sesa = '1'
    mais ça ne change rien. Quelle serait la bonne requête , SVP ?

  2. #2
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 486
    Billets dans le blog
    1
    Par défaut
    Tous comptes faits, mon bug n'était pas là où je le croyais quand j'ai écrit mon post : la clause WHERE doit porter sur une autre colonne ! La version simplifiée de la requête fonctionne en effet :

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT US.US_firstname,US.US_lastname,US.US_sesa FROM LI_license LI
    JOIN US_user US ON LI.US_ident = US.US_ident
    WHERE US.US_ident = '2'

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

Discussions similaires

  1. Requête sql avec jointure qui ne fonctionne pas
    Par Damien062 dans le forum PHP & Base de données
    Réponses: 9
    Dernier message: 10/03/2015, 09h18
  2. Grosse requête avec jointure qui ne s'exécute plus
    Par pitichamo dans le forum Requêtes
    Réponses: 5
    Dernier message: 22/11/2013, 16h45
  3. Requête avec jointure qui retourne null si pas de valeur
    Par jubourbon dans le forum Langage SQL
    Réponses: 2
    Dernier message: 02/09/2011, 11h10
  4. [Toutes versions] Requête SQL avec VBA qui ne retourne rien
    Par Roums dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 07/01/2011, 10h37
  5. requête avec jointure qui renvoie des résultats bizarres
    Par Canari74 dans le forum Requêtes et SQL.
    Réponses: 0
    Dernier message: 20/05/2008, 02h13

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