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

DB2 Discussion :

Requete / filtre sur le MAX d'une colonne


Sujet :

DB2

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    96
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Mars 2008
    Messages : 96
    Points : 69
    Points
    69
    Par défaut Requete / filtre sur le MAX d'une colonne
    Je dispose de 2 tables

    la table t1 contient les colonnes ID, ALPHA et NUM
    la table t2 contient les colonnes ID, ANNEE, NB et ID_T1

    La requête ci-joint :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
      SELECT ALPHA, NUM, ANNEE, NB
        FROM t1, t2
       WHERE t1.ID = t2.ID_T1
    ORDER BY ANNEE;
    qui me retourne, par exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    -------+---------+---------+---------+
    ALPHA   NUM          ANNEE          NB
    -------+---------+---------+---------+
    A         1           1966         4
    A         2           1966        12
    A         3           1967        16
    A         4           1970        26
    A         4           1971        67
    F         5           1971         5
    E         5           1972         9
    D         5           1973         1
    Mon problème : j'aimerais que la requête me retourne un enregistrement unique par colonne ANNEE avec comme critère le NB le plus grand

    En reprenant mon exemple, j'obtiens donc :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    -------+---------+---------+---------+
    ALPHA   NUM          ANNEE          NB
    -------+---------+---------+---------+
    A         2           1966        12
    A         3           1967        16
    A         4           1970        26
    A         4           1971        67
    E         5           1972         9
    D         5           1973         1
    Merci pour votre aide.

  2. #2
    Membre éprouvé
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    821
    Détails du profil
    Informations personnelles :
    Âge : 54
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations forums :
    Inscription : Mai 2008
    Messages : 821
    Points : 1 084
    Points
    1 084
    Par défaut
    Essaye ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    with f0 as (                           
      SELECT ALPHA, NUM, ANNEE, NB         
        FROM t1 join  t2       
          on  t1.ID = t2.ID_T1),           
         f1 as (Select Annee, max(NB) maxi 
                from f0 Group by Annee)    
    Select * from f1 join f0               
     on f1.Annee = f0.annee                
    and f1.Maxi  = f0.nb
    ou celle-ci (pour laquelle j'ai une préférence)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    with f0 as (                                             
      SELECT ALPHA, NUM, ANNEE, NB                           
     , rank() over (partition by annee order by nb desc) Rang
        FROM t1 join  t2                         
          on  t1.ID = t2.ID_T1)                              
    Select * from f0 
    Where rang = 1

Discussions similaires

  1. [DeskI V5-V6] Filtrer sur le Max d'une colonne
    Par antakini dans le forum Débuter
    Réponses: 2
    Dernier message: 13/02/2014, 14h10
  2. [AC-2003] Garder une ligne sur 8, selon le max d'une colonne
    Par alex3084 dans le forum Access
    Réponses: 3
    Dernier message: 12/04/2012, 19h40
  3. [XL-2003] Trouver le min et le max d'une colonne dans une plage filtrée
    Par Gwladys dans le forum Excel
    Réponses: 2
    Dernier message: 06/04/2009, 17h37
  4. Requete select avec MAX d'une colonne.
    Par lolymeupy dans le forum Requêtes
    Réponses: 15
    Dernier message: 08/08/2008, 10h07
  5. filtre WHERE sur premier caractère d'une colonne
    Par Maljuna Kris dans le forum Requêtes
    Réponses: 8
    Dernier message: 20/11/2005, 18h52

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