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

Sélection avec inclusion/exclusion sur un même champ


Sujet :

Langage SQL

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    13
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 13
    Points : 12
    Points
    12
    Par défaut Sélection avec inclusion/exclusion sur un même champ
    Bonjour,

    Ma table comprend deux champs : id_user et id_group. Un même utilisateur peut appartenir à plusieurs groupes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    id_user | id_group
    ------------------
    1       | 1
    1       | 2
    2       | 2
    3       | 1
    4       | 1
    4       | 2
    5       | 1
    Je cherche à faire une requête qui me retourne tous les utilisateurs qui appartiennent au groupe 1 mais pas au groupe 2. Avec la table précédente, les utilisateurs 3 et 5.

    Vous l'aurez compris, je ne suis pas au point en SQL.

    Merci pour l'aide que vous pourriez m'apporter.

    Hervé Soulard.

  2. #2
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 048
    Points
    34 048
    Billets dans le blog
    14
    Par défaut
    Je ne vais pas te donner la solution toute faite mais t'aiguiller vers elle.

    Fais une requête qui cherche les utilisateurs appartenant au groupe 1.
    Fais en une autre qui cherche les utilisateur appartenant au groupe 2.
    Relie les deux par une clause NOT EXISTS dans le WHERE de la première requête.

    Essaie de construire la requête tout seul et reviens nous voir si tu n'y arrives pas.

    Tu peux regarder ce tuto pour t'aider.

    Bon courage !

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    13
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 13
    Points : 12
    Points
    12
    Par défaut
    > Fais une requête qui cherche les utilisateurs appartenant au groupe 1.
    > Fais en une autre qui cherche les utilisateur appartenant au groupe 2.

    Ca j'y arrive :-)

    > Relie les deux par une clause NOT EXISTS dans le WHERE de la première requête.

    Là je ne vois pas.

    Si j'ai bien compris le fonctionnement de EXISTS, à partir du moment où la 2e requête (interne) va trouver quelque chose, la 1ere (externe) sera exécutée. Puisque j'ai des utilisateurs dans le groupe 2, le NOT EXISTS va toujours être False et la 1ere ne sera donc pas exécutée.

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

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    Bonjour,


    Non pas exactement.

    Pour chaque ligne de la requête mère un teste d'existance dans la sous-requête va être effectué.

    Si ce test est concluant la ligne sera sélectionnée

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    13
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 13
    Points : 12
    Points
    12
    Par défaut
    > Non pas exactement.
    > Pour chaque ligne de la requête mère un teste d'existance dans la sous-requête va être effectué.
    > Si ce test est concluant la ligne sera sélectionnée

    OK, alors je propose ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SELECT * 
    FROM   table t 
    WHERE  id_group = 1 
           AND NOT EXISTS (SELECT * 
                           FROM   table 
                           WHERE  id_user = t.id_user 
                                  AND id_group = 2)
    Elle fonctionne avec le petit exemple de table, mais est-elle correcte de façon générale ?

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

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


    oui c'est la bonne solution

  7. #7
    Membre à l'essai
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    13
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 13
    Points : 12
    Points
    12
    Par défaut
    > oui c'est la bonne solution

    Super. Merci à vous deux.

  8. #8
    Membre émérite Avatar de pacmann
    Homme Profil pro
    Consulté Oracle
    Inscrit en
    Juin 2004
    Messages
    1 626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Consulté Oracle
    Secteur : Distribution

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 626
    Points : 2 845
    Points
    2 845
    Par défaut
    Salut,

    Je sais pas trop pourquoi, mais ici j'aime bien :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SELECT id_user
    FROM t
    WHERE id_group = 1
    EXCEPT
    SELECT id_user
    FROM t
    WHERE id_group = 2
    (Remplacer EXCEPT par MINUS sous Oracle)

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

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    et la solution sans jointure !

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    select id_user
    from ma_table
    where id_group in (1, 2)
    group by id_user
    having sum(case when id_group = 1 then 1 else 2 end) = 1

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

Discussions similaires

  1. Requête avec conditions multiples (OR/AND) sur le même champ
    Par GueloSuperStar dans le forum Langage SQL
    Réponses: 31
    Dernier message: 05/03/2013, 10h42
  2. Réponses: 7
    Dernier message: 24/09/2012, 23h12
  3. Requête avec conditions multiples sur le même champ
    Par skerdreux dans le forum Langage SQL
    Réponses: 2
    Dernier message: 25/06/2008, 19h15
  4. Réponses: 4
    Dernier message: 26/04/2006, 14h02
  5. [SQL]Requete avec 2 count(*) sur la même table
    Par Sonny dans le forum Langage SQL
    Réponses: 5
    Dernier message: 06/11/2005, 16h41

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