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 MAX d'une date


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Février 2006
    Messages
    243
    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 : 243
    Par défaut GROUP BY avec MAX d'une date
    Bonjour
    J'ai des données de production et j'aimerai pouvoir sortir la quantité de produit par mois.
    Sauf que pour ça il me faut récupérer la dernière valeur "full_date" dans les enregistrements de production avec des groupements comme suit:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    SELECT
        Production_nom,
        P_nr_commande,
        NumBobine,
        MAX(full_date) AS 'date_max'
    FROM
        final
    GROUP BY
        Production_nom,
        P_nr_commande,
        NumBobine
    J'ai donc créé une vue "Vue_regroupement" avec ce code
    Et ensuite je fais une requête sur la vue pour obtenir les stats
    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
     
    SELECT
        YEAR('date_max'),
        MONTH('date_max'),
        Production_nom,
        P_nr_commande,
        COUNT(NumBobine) AS 'Total_bobine'
    FROM
        "Vue_regroupement"
    GROUP BY
        YEAR('date_max'),
        MONTH('date_max'),
        Production_nom,
        P_nr_commande,
     
    ORDER BY
        YEAR('date_max'),
        MONTH('date_max'),
        Production_nom,
        P_nr_commande,
    Question : est-il possible de faire celà en une seule requête sans passer par ma vue intermédiaire?

  2. #2
    Invité
    Invité(e)
    Par défaut
    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
    ; with TOTO as (
    	SELECT
    		Production_nom,
    		P_nr_commande,
    		NumBobine,
    		MAX(full_date) AS 'date_max'
    	FROM final
    	GROUP BY
    		Production_nom,
    		P_nr_commande,
    		NumBobine
    )
    SELECT
    	YEAR('date_max'),
    	MONTH('date_max'),
    	Production_nom,
    	P_nr_commande,
    	COUNT(NumBobine) AS 'Total_bobine'
    FROM TOTO
    GROUP BY
    	YEAR('date_max'),
    	MONTH('date_max'),
    	Production_nom,
    	P_nr_commande,
    ORDER BY
    	YEAR('date_max'),
    	MONTH('date_max'),
    	Production_nom,
    	P_nr_commande;

Discussions similaires

  1. Requête SQL avec function MAX() sur une date
    Par mehdiyou1985 dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 03/12/2012, 21h52
  2. Clé primaire d'une requete GROUP BY avec MAX
    Par befb dans le forum Requêtes et SQL.
    Réponses: 11
    Dernier message: 30/07/2010, 09h29
  3. Select avec max sur une date
    Par olibara dans le forum Requêtes
    Réponses: 10
    Dernier message: 06/07/2010, 07h18
  4. Réponses: 6
    Dernier message: 26/07/2005, 10h20
  5. Requete de suppression avec en condition une date
    Par PrinceMaster77 dans le forum Langage SQL
    Réponses: 3
    Dernier message: 29/04/2004, 09h23

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