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

 MySQL Discussion :

un IN un petit peu complexe


Sujet :

MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2008
    Messages
    88
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 88
    Par défaut un IN un petit peu complexe
    Bonsoir,

    Je ne sais meme pas si ce que je demande est possible avec un IN mais il faudrait vraiment que j'utilise un IN si possible.

    J'ai une table qui sert à faire une jointure entre deux tables. Elle contient donc les ID des 2 tables.
    Voici un extrait de la table (IDs) avec ses deux champs:

    ID1 | ID2
    1 | 10
    1 | 20
    1 | 30
    2 | 10
    2 | 40
    3 | 30
    4 | 50
    4 | 60
    4 | 20
    4 | 10
    4 | 80

    J'aimerai selectionner tous les ID1 qui ont soit un couple ID2 (10,20) ou un couple ID2 (60,80). J'insiste sur le fait que les deux valeurs du couple doivent etre présentes.

    Donc les résultats ID1 retournés devraient être 1 et 4.

    Est ce possible de faire ceci avec un IN ?

    Pour un seul couple j'y arrive en faisant ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT  * 
    FROM IDs 
    WHERE ID2 IN ("10","20") 
    GROUP BY ID1 
    HAVING count(*) = "2"
    Par contre quand il s'agit de faire ceci avec 2 couples ou plus, je n'y arrive pas du tout :/

    Une aide serait la bienvenue car cette requete me bloque aujourd'hui dans mon travail.

    Merci d'avance

  2. #2
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 953
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 953
    Par défaut
    Qu'est ce que ça donne comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    select id1
      from t
     where id2 in (10,20,60,80)
     group by id1
    having count(distinct case when id2 in (10,20) then id2 end) = 2
        or count(distinct case when id2 in (60,80) then id2 end) = 2
    Le DISTINCT n'étant pas obligatoire si le couple (id1,id2) est unique

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2008
    Messages
    88
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 88
    Par défaut
    Ouaw quelle requete ! merci c'est juste parfait !

    Par contre si j'ai un troisième couple qui utilise une valeur déjà utilisée je peux l'ajouter comme ceci à la suite ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT id1
      FROM t
     WHERE id2 IN (10,20,60,80,40)
     GROUP BY id1
    HAVING count(DISTINCT case when id2 IN (10,20) then id2 end) = 2
        OR count(DISTINCT case when id2 IN (60,80) then id2 end) = 2
        OR count(DISTINCT case when id2 IN (10,40) then id2 end) = 2

  4. #4
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 953
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 953
    Par défaut
    Citation Envoyé par ghostfile Voir le message
    Par contre si j'ai un troisième couple qui utilise une valeur déjà utilisée je peux l'ajouter comme ceci à la suite ?
    Oui c'est le HAVING qui fait la règle de gestion le IN ne sert qu'à sélectionner l'ensemble des valeurs sur lesquelles travaillées.

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2008
    Messages
    88
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 88
    Par défaut
    Ok merci beaucoup !! Vraiment !

    Bonne soirée

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

Discussions similaires

  1. Gérer un Formulaire un peu complexe pour moi
    Par budylove dans le forum Langage
    Réponses: 3
    Dernier message: 17/05/2006, 10h01
  2. Un Alignement un peu complexe
    Par Jeskor dans le forum Balisage (X)HTML et validation W3C
    Réponses: 6
    Dernier message: 27/04/2006, 17h04
  3. Requête de sélection un peu complexe
    Par new_wave dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 03/01/2006, 14h44
  4. Requete un peu complexe avec la fonction IN
    Par Taichin dans le forum Oracle
    Réponses: 27
    Dernier message: 10/11/2004, 08h59

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