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 :

Requête SQL où il n'y a pas (quelle condition)


Sujet :

Langage SQL

  1. #1
    Rédacteur

    Homme Profil pro
    Technical Lead Salesforce
    Inscrit en
    Février 2009
    Messages
    563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Technical Lead Salesforce

    Informations forums :
    Inscription : Février 2009
    Messages : 563
    Points : 1 667
    Points
    1 667
    Par défaut Requête SQL où il n'y a pas (quelle condition)
    Bonjour, j'ai une BDD SQL où j'ai 3 tables.

    La première, est celle qui concerne les étudiants (idEtudiant, nom, prenom, idClasse), la seconde concerne des projets (idProjet, nom), ces deux tables ont une relation n à n donc un étudiant peut avoir fait 1 à n projets et un projet peut être fait par 1 à n étudiant d'où la troisième table (idEtudiant, idProjet).

    Je souhaiterais faire une requête SQL pour connaître tout les étudiants qui n'ont pas participé à un projet mais je suis un peu perdu à la condition qu'il faut mettre.

    Que puis-je faire svp?

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 102
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 102
    Points : 28 392
    Points
    28 392
    Par défaut
    Le prédicat EXISTS devrait répondre à ton besoin, tout aussi bien que l'opérateur IN ou une jointure externe.
    Code : 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
    SELECT  etd.idetudiant
    FROM    etudiant    AS etd
    WHERE   NOT EXISTS
            (   SELECT  1
                FROM    marelation  AS rel
                WHERE   rel.idetudiant = etd.idetudiant
            )
    ;
    SELECT  etd.idetudiant
    FROM    etudiant    AS etd
    WHERE   etd.idetudiant  NOT IN
            (   SELECT  rel.idetudiant
                FROM    marelation  AS rel
            )
    ;
    SELECT  etd.idetudiant
    FROM    etudiant    AS etd
        LEFT JOIN
            marelation  AS rel
            ON  rel.idetudiant = etd.idetudiant
    WHERE   rel.idetudiant  IS NULL
    ;
    A toi de choisir le plus efficace en fonction de ton SGBD.

  3. #3
    Rédacteur

    Homme Profil pro
    Technical Lead Salesforce
    Inscrit en
    Février 2009
    Messages
    563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Technical Lead Salesforce

    Informations forums :
    Inscription : Février 2009
    Messages : 563
    Points : 1 667
    Points
    1 667
    Par défaut
    La deuxième me va mieux:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SELECT  etd.idetudiant
    FROM    etudiant    AS etd
    WHERE   etd.idetudiant  NOT IN
            (   SELECT  rel.idetudiant
                FROM    marelation  AS rel
            )
    ;
    Je savais bien qu'il y avait quelque chose comme NOT IN qui existait, sujet résolu, merci.

+ 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. Réponses: 8
    Dernier message: 05/03/2012, 15h36
  3. [Requête SQL] fonctionne en WD10 pas en WD9
    Par moabomotal dans le forum WinDev
    Réponses: 3
    Dernier message: 06/12/2006, 18h11
  4. Réponses: 2
    Dernier message: 04/03/2006, 10h47
  5. Réponses: 2
    Dernier message: 06/06/2005, 15h13

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