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 :

Trier résultats (Group By)


Sujet :

Langage SQL

  1. #1
    Membre expérimenté
    Avatar de sat83
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2004
    Messages
    1 040
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Haut Rhin (Alsace)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 040
    Points : 1 307
    Points
    1 307
    Par défaut Trier résultats (Group By)
    Bonjour à tous,

    J'ai une table comprenant 3 champs: NOM, CODE_EXAM, DATE_EXAM.

    Pour obtenir la liste des examen classé par nom, puis par date je fais:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT NOM, MATIERE, DATE_EXAM
    FROM MATABLE
    ORDER BY NOM, DATE_EXAM
    J'obtiens un résultat du genre:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    AAA      P2-1        13/01/10                  
    AAA      PE01        14/01/10                  
    AAA      P201        14/01/10                  
    BBB      P2-1        16/01/10                  
    BBB      PE01        16/01/10                  
    BBB      P201        16/01/10                  
    CCC      P2-1        14/01/10                  
    CCC      PE01        15/01/10                  
    CCC      P201        15/01/10                  
    DDD      P2-1        11/01/10                  
    DDD      PE01        12/01/10                  
    DDD      P201        12/01/10
    Je voudrais maintenant obtenir le même résultat, mais en obtenant d'abord la personne ayant réalisé un examen en premier, pour obtenir :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    DDD      P2-1        11/01/10                  
    DDD      PE01        12/01/10                  
    DDD      P201        12/01/10 
    AAA      P2-1        13/01/10                  
    AAA      PE01        14/01/10                  
    AAA      P201        14/01/10                                  
    CCC      P2-1        14/01/10                  
    CCC      PE01        15/01/10                  
    CCC      P201        15/01/10
    BBB      P2-1        15/01/10                  
    BBB      PE01        16/01/10                  
    BBB      P201        16/01/10
    En gros, je voudrais un compromis entre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ORDER BY NOM, DATE_EXAM
    et
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ORDER BY DATE_EXAM, NOM
    Merci d'avance pour votre aide!
    Ce que l'on apprend par l'effort reste toujours ancré plus longtemps...

  2. #2
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 820
    Points
    17 820
    Par défaut
    Quel SGBD ?

  3. #3
    Membre expérimenté
    Avatar de sat83
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2004
    Messages
    1 040
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Haut Rhin (Alsace)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 040
    Points : 1 307
    Points
    1 307
    Par défaut
    Je suis sous ORACLE 9
    Ce que l'on apprend par l'effort reste toujours ancré plus longtemps...

  4. #4
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 820
    Points
    17 820
    Par défaut
    Essayez ainsi :
    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
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    With MaTable as
    (
    select 'AAA' as nom, 'P2-1' as mat, to_date('13/01/10', 'dd/mm/rr') as date_exam from dual union all
    select 'AAA'       , 'PE01'       , to_date('14/01/10', 'dd/mm/rr')              from dual union all
    select 'AAA'       , 'P201'       , to_date('14/01/10', 'dd/mm/rr')              from dual union all
    select 'BBB'       , 'P2-1'       , to_date('16/01/10', 'dd/mm/rr')              from dual union all
    select 'BBB'       , 'PE01'       , to_date('16/01/10', 'dd/mm/rr')              from dual union all
    select 'BBB'       , 'P201'       , to_date('16/01/10', 'dd/mm/rr')              from dual union all
    select 'CCC'       , 'P2-1'       , to_date('14/01/10', 'dd/mm/rr')              from dual union all
    select 'CCC'       , 'PE01'       , to_date('15/01/10', 'dd/mm/rr')              from dual union all
    select 'CCC'       , 'P201'       , to_date('15/01/10', 'dd/mm/rr')              from dual union all
    select 'DDD'       , 'P2-1'       , to_date('11/01/10', 'dd/mm/rr')              from dual union all
    select 'DDD'       , 'PE01'       , to_date('12/01/10', 'dd/mm/rr')              from dual union all
    select 'DDD'       , 'P201'       , to_date('12/01/10', 'dd/mm/rr')              from dual
    )
      select nom, mat, to_char(date_exam, 'dd/mm/rr') as date_exam
        from matable
    order by min(date_exam) over(partition by nom) asc,
             nom, date_exam;
     
    NOM	MAT	DATE_EXAM
    DDD	P2-1	11/01/10
    DDD	PE01	12/01/10
    DDD	P201	12/01/10
    AAA	P2-1	13/01/10
    AAA	P201	14/01/10
    AAA	PE01	14/01/10
    CCC	P2-1	14/01/10
    CCC	P201	15/01/10
    CCC	PE01	15/01/10
    BBB	P2-1	16/01/10
    BBB	PE01	16/01/10
    BBB	P201	16/01/10

  5. #5
    Membre expérimenté
    Avatar de sat83
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2004
    Messages
    1 040
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Haut Rhin (Alsace)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 040
    Points : 1 307
    Points
    1 307
    Par défaut
    Impeccable, ça fonctionne, merci beaucoup!
    Ce que l'on apprend par l'effort reste toujours ancré plus longtemps...

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

Discussions similaires

  1. [MySQL] Plusieurs résultats groupés
    Par juno107 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 17/02/2009, 14h50
  2. [CR11] Besoin d'aide pour trier résultat
    Par Hartdrooz dans le forum Formules
    Réponses: 2
    Dernier message: 21/07/2008, 16h55
  3. [Formulaire]Trier par groupe défini
    Par Harmony dans le forum IHM
    Réponses: 1
    Dernier message: 26/03/2007, 16h57
  4. [Conception] Trier résultat d'une requête
    Par iomega dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 28/09/2006, 17h19
  5. Trier résultats selon un critère
    Par jersey_girl dans le forum Requêtes
    Réponses: 4
    Dernier message: 06/09/2006, 09h43

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