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

Filtrer un élément sur plusieurs lignes


Sujet :

Requêtes MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2014
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Octobre 2014
    Messages : 2
    Par défaut Filtrer un élément sur plusieurs lignes
    Bonjour,

    Je bloque sur une requête qui me semble toute simple

    J'ai une table avec 2 colonnes :

    colonneX colonneY
    A 1
    B 1
    B 2
    B 3
    C 5
    D 2
    D 1
    E 4

    J'aimerais récupérer tous les éléments de la colonne X qui ont un lien vers les éléments 2 et 3 de la colonne Y. Dans l'exemple ci-dessus, il n'y a que B qui corresponde.

    La requête ne me semble pas bien compliqué, mais je n'arrive pas à la trouver. Avez-vous une idée,

    Merci,

    Vence

  2. #2
    Nouveau candidat au Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2014
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Octobre 2014
    Messages : 2
    Par défaut
    J'ai peut-être une piste (pas si simple que ça en fait ...)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT *, GROUP_CONCAT(colonneY) AS colonneList
    FROM table
    WHERE colonneY IN (2,3)
    GROUP BY colonneX
    HAVING COUNT(*) = 2
    Le résultat a pas l'air mal. Qu'en pensez-vous ?

  3. #3
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Par défaut
    bonjour,

    c'est la bonne solution

  4. #4
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Par défaut
    Bonjour,

    C'est en effet une solution correcte si vous avez un contrainte empêchant d'avoir des doublons dans la colonneY pour une valeur de X données. Donc une contrainte d'unicité sur le couple (colonneX colonneY)

    Dans le cas contraire, si dans votre exemple vous ajoutez une deuxième ligne D 2, alors, D ressortira.
    Vous pouvez ajouter un DISTINCT dans le COUNT() pour éviter cela (mais ça dépend aussi de vos règles de gestion dans ce cas)

Discussions similaires

  1. Ecrire une requete SQL sur plusieurs lignes
    Par PrinceMaster77 dans le forum ASP
    Réponses: 2
    Dernier message: 15/11/2004, 14h47
  2. Response.Write sur plusieurs lignes
    Par simoryl dans le forum ASP
    Réponses: 2
    Dernier message: 31/08/2004, 22h49
  3. Réponses: 2
    Dernier message: 10/05/2004, 07h55
  4. TDBGrid - Un enregistrement sur plusieurs lignes
    Par BRODU dans le forum Bases de données
    Réponses: 2
    Dernier message: 09/05/2004, 07h53
  5. Define sur plusieurs lignes
    Par Gogoye dans le forum C
    Réponses: 6
    Dernier message: 06/10/2003, 11h45

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