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 :

SELECT dans une requête compliquée


Sujet :

Langage SQL

  1. #1
    Membre du Club
    Homme Profil pro
    Consultant E-Business
    Inscrit en
    Novembre 2012
    Messages
    54
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Consultant E-Business
    Secteur : Industrie

    Informations forums :
    Inscription : Novembre 2012
    Messages : 54
    Points : 46
    Points
    46
    Par défaut SELECT dans une requête compliquée
    Bonjour,
    Je cherche à récupérer la liste des étudiants dans une table ou on peut trouver le même étudiant plusieurs fois car il a plusieurs diplômes (par exemple: on va trouver le tuple pour licence et ensuite on va le trouver avec le diplôme Master) moi je cherche à récupérer la liste ou des étudiants avec seulement leurs dernier diplôme.
    Je sais le faire lorsque je connais le nom de l'étudiant:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    SELECT * 
    FROM  `annu_annuaire` 
    WHERE Nom_etu =  "Jean"
    AND (
    promotion
    IN (
     
    SELECT MAX( promotion ) 
    FROM  `annu_annuaire` 
    WHERE Nom_etu =  "Jean"
    )
    )
    Maintenant je veux généraliser cette requête pour récupérer la liste de tout les étudiants.

    Merci pour le coup de main

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    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 080
    Points : 30 813
    Points
    30 813
    Par défaut
    Il suffit d'utiliser des alias sur les noms de tables et une sous-requête corrélée.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    SELECT  * 
    FROM    annu_annuaire an1
    WHERE   an1.Nom_etu = 'Jean'
      AND   an1.promotion
            IN  (   SELECT  MAX(an2.promotion ) 
                    FROM    annu_annuaire an2 
                    WHERE   an2.Nom_etu =  an1.Nom_etu)
                )
    ;
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  3. #3
    Membre du Club
    Homme Profil pro
    Consultant E-Business
    Inscrit en
    Novembre 2012
    Messages
    54
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Consultant E-Business
    Secteur : Industrie

    Informations forums :
    Inscription : Novembre 2012
    Messages : 54
    Points : 46
    Points
    46
    Par défaut
    Salut,
    Merci pour votre réponse.
    mais en fait
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WHERE   an1.Nom_etu = 'Jean'
    je ne dois pas choisir de nom mais faire une requête général sur toute la table.

    Je pense à faire ça:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select max(promotion), Nom_etu from annu_annuaire group by Nom_etu
    Vous pensez que c'est une méthode propre de faire?

  4. #4
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    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 080
    Points : 30 813
    Points
    30 813
    Par défaut
    J'vais répondu un peu rapidement. Pour généraliser, il suffit de retirer la restriction sur an1.Nom_etu = 'Jean'.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT  * 
    FROM    annu_annuaire an1
    WHERE   an1.promotion
            IN  (   SELECT  MAX(an2.promotion ) 
                    FROM    annu_annuaire an2 
                    WHERE   an2.Nom_etu =  an1.Nom_etu)
                )
    ;
    La requête que tu proposes ne répond pas au même besoin puisqu'elle ne retourne que le nom de l'étudiant et sa promotion.
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  5. #5
    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
    Points : 13 092
    Points
    13 092
    Par défaut
    Bonjour,

    Vous pouvez faire une jointure avec une sous requete indiquant la date max par etudiant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    SELECT  an1.* 
    FROM    annu_annuaire an1
    INNER JOIN(   
        SELECT   Nom_etu, MAX(an2.promotion)  as dte
        FROM     annu_annuaire
        GROUP BY Nom_etu
    ) AS M
        ON M.Nom_etu = an1.Nom_etu
        AND M.dte = an1.promotion

Discussions similaires

  1. [PDO] SELECT dans une requète SQL sur une page PHP
    Par thewit dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 19/01/2015, 22h48
  2. [AC-2007] Sous-requête "Select" dans une requête "update"
    Par MatAllwhite dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 27/06/2013, 14h00
  3. Réponses: 1
    Dernier message: 28/04/2009, 09h57
  4. Réponses: 7
    Dernier message: 20/08/2007, 16h40
  5. Inclure un SELECT dans une requète Update
    Par carolinebelle dans le forum Langage SQL
    Réponses: 2
    Dernier message: 19/07/2005, 14h19

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