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

Développement SQL Server Discussion :

GROUP BY avec élément spécifique [2008R2]


Sujet :

Développement SQL Server

  1. #1
    Membre régulier
    Homme Profil pro
    Inscrit en
    Février 2006
    Messages
    242
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2006
    Messages : 242
    Points : 94
    Points
    94
    Par défaut GROUP BY avec élément spécifique
    Bonjour
    J'ai une table comme ceci
    STO_ID,STO_DATE,STO_NUM,STO_REM

    J'aimerai en fait obtenir par regroupement sur STO_NUM, le MAX(STO_DATE) et le valeur de la colonne STO_REM correspondant à ce MAX(STO_DATE)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT
         STO_NUM,
         MAX(STO_DATE)
    FROM
         T_STOCK_STO
    GROUP BY
         STO_NUM
    D'avance merci pour votre aide

  2. #2
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 947
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 947
    Points : 5 846
    Points
    5 846
    Par défaut
    La réponse dépend des fonctionnalités disponibles dans votre SGBD que vous n'avez pas précisé :
    - fonction analytique (ou de fenêtrage) row_number ou rank
    - first/last
    - jointure sur la sous-requête déterminant le max(date)

    [edit] : avec sqlserver 2008 utilisez row_number ou rank

  3. #3
    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
    alors vous pouvez faire comme ceci :


    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
     
    WITH CTE AS (
    SELECT
         STO_NUM,
         STO_DATE,
         STO_REM,
         ROW_NUMBER() OVER( PARTITION BY STO_NUM ORDER BY STO_DATE DESC) AS Rang
    FROM
         T_STOCK_STO
    GROUP BY
         STO_NUM
    )
    SELECT 
         STO_NUM,
         STO_DATE,
         STO_REM
    FROM CTE
    WHERE Rang = 1

  4. #4
    Membre régulier
    Homme Profil pro
    Inscrit en
    Février 2006
    Messages
    242
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2006
    Messages : 242
    Points : 94
    Points
    94
    Par défaut
    Merci
    Je ne connaissais pas cette fonction ROW_NUMBER()

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

Discussions similaires

  1. [Access] Clause GROUP BY avec une date
    Par Kanie dans le forum Langage SQL
    Réponses: 4
    Dernier message: 10/04/2006, 19h58
  2. Réponses: 1
    Dernier message: 18/01/2006, 17h51
  3. Groupe By avec jointure
    Par batoubat dans le forum Langage SQL
    Réponses: 4
    Dernier message: 27/12/2005, 14h12
  4. Réponses: 16
    Dernier message: 25/11/2005, 09h53
  5. Group by, jointure, élément vide
    Par Tan dans le forum Langage SQL
    Réponses: 11
    Dernier message: 24/11/2004, 13h48

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