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 PHP Discussion :

Select qui ne retoune pas ce que je désire


Sujet :

Langage PHP

  1. #1
    Membre éprouvé
    Avatar de beegees
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2004
    Messages
    3 610
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2004
    Messages : 3 610
    Points : 1 277
    Points
    1 277
    Par défaut Select qui ne retoune pas ce que je désire
    Bonsoir,

    J'ai une table qui contient ceci :
    Guide Langue

    1 1

    1 2

    1 3

    2 1

    2 2

    Je voudrais sélectionner les personnes qui ont 1,2 et 3 (ici le 1).

    J'ai codé cette chaine SQL, mais j'ai l'impression que cette dernière demande que le champ soit 1 ET 2 ET 3

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT guides.id, guides.nom, guides.prenom, langues.langue
    FROM guides 
    JOIN guides_has_langues ON guides_has_langues.guides_id = guides.id
    JOIN langues ON guides_has_langues.langues_id = langues.id
    WHERE guides_has_langues.langues_id = 1 AND guides_has_langues.langues_id = 2 AND guides_has_langues.langues_id = 3

    Qu'en pensez-vous ?

    Merci d'avance pour l'aide.

    bee

  2. #2
    Membre averti
    Homme Profil pro
    Inscrit en
    Juillet 2012
    Messages
    200
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Bénin

    Informations forums :
    Inscription : Juillet 2012
    Messages : 200
    Points : 342
    Points
    342
    Par défaut Utiliser OR au lieu de AND
    Bonsoir. Il me semble que vous devriez utiliser une condition OR au lieu du ET. Votre requête demande de choisir les enregistrements dont le guides_has_langues.langues_id soit à la fois égal à 1, 2 et 3. Ce qui est impossible.
    Le code correct est donc
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT guides.id, guides.nom, guides.prenom, langues.langue
    FROM guides 
        JOIN guides_has_langues ON guides_has_langues.guides_id = guides.id
        JOIN langues ON guides_has_langues.langues_id = langues.id
    WHERE guides_has_langues.langues_id = 1
        OR guides_has_langues.langues_id = 2
        OR guides_has_langues.langues_id = 3

  3. #3
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Plus court :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    WHERE guides_has_langues.langues_id IN (1, 2, 3)
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  4. #4
    Membre averti
    Homme Profil pro
    Inscrit en
    Juillet 2012
    Messages
    200
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Bénin

    Informations forums :
    Inscription : Juillet 2012
    Messages : 200
    Points : 342
    Points
    342
    Par défaut
    @sabotage +1

  5. #5
    Membre éprouvé
    Avatar de beegees
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2004
    Messages
    3 610
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2004
    Messages : 3 610
    Points : 1 277
    Points
    1 277
    Par défaut
    Salut,

    Merci à vous deux pour vos réponses.

    En fait, en plus d'utiliser OR (ou plutôt iN), je devais faire ceci :

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT guides.id, guides.nom, guides.prenom, GROUP_CONCAT(langues.langue)
    FROM guides
        JOIN guides_has_langues ON guides_has_langues.guides_id = guides.id
        JOIN langues ON guides_has_langues.langues_id = langues.id
    WHERE guides_has_langues.langues_id IN  (1,2) 
    GROUP BY guides.id, guides.nom, guides.prenom 
    HAVING COUNT(DISTINCT guides_has_langues.langues_id) = 2

    J'espère que cela servira à quelqu'un.

    Merci pour l'aide.

    bee

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

Discussions similaires

  1. requête de selection qui ne fonctionne pas
    Par emmablue dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 28/07/2006, 13h55
  2. Socket, recv et select qui ne marche pas
    Par Zapan dans le forum Réseau
    Réponses: 18
    Dernier message: 30/06/2006, 20h19
  3. [MySQL] Boucle qui ne fonctionne pas bien que la 1ère fois
    Par R.L. dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 27/05/2006, 21h59
  4. Select qui n'existe pas
    Par daijoubu dans le forum Langage SQL
    Réponses: 2
    Dernier message: 12/01/2006, 18h34
  5. Réponses: 18
    Dernier message: 13/12/2005, 13h27

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