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

MS SQL Server Discussion :

afficher les 10 premiers enregistrements pour chaque groupe


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Inscrit en
    Septembre 2006
    Messages
    365
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 365
    Par défaut afficher les 10 premiers enregistrements pour chaque groupe
    Bonjour,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    select R.categorie, R.article, avg(R.ventes) as average_ventes from (select distinct categorie, article, ventes from ARTICLES a 
    join CATEGORIES C on a.article= s.article) R
    group by R.article, R.categorie
    order by R.categorie, average_ventes desc
    ceci me génère des enregistrements de la forme:
    Categorie......Article.....Moyenne des ventes


    En fait je voudrais une liste des 10 articles les mieux vendus par catégorie, en gros, les 10 premières lignes de chaque catégorie (selon ce code sql)

    des idées? Merci..

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 998
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 998
    Billets dans le blog
    6
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    SELECT categorie, article, average_ventes
    FROM   (SELECT *, ROW_NUMBER() OVER(PARTITION BY categorie, article ORDER BY average_ventes) As N
            FROM (SELECT categorie, article, avg(ventes) AS average_ventes 
                  FROM   ARTICLES a 
                         INER JOIN CATEGORIES C ON a.article= C.article) R
                  GROUP BY R.article, R.categorie
                 ) AS T 
           ) AS TT
    WHERE N <= 10

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  3. #3
    Membre éclairé
    Inscrit en
    Septembre 2006
    Messages
    365
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 365
    Par défaut
    merci deja..

    mais ce code ne marche pas.. d'abord il me renvoie une erreur de syntaxe car le avg est sans group by..
    si j'enléve les parenthèses pour avoir ce code là:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    SELECT categorie, article, average_ventes
    FROM   (SELECT *, ROW_NUMBER() OVER(PARTITION BY categorie, article ORDER BY average_ventes) AS N
            FROM (SELECT categorie, article, avg(ventes) AS average_ventes 
                  FROM   ARTICLES a 
                         INER JOIN CATEGORIES C ON a.article= C.article
                  GROUP BY article, categorie
                 ) AS T 
           ) AS TT
    WHERE N <= 10
    j'obtiens N = 1 partout..


    L'idée est là.. c'est de numéroter les lignes pour chaque groupe, et finir par un where N <=10, mais j'ai beau cherché, je ne sais pas comment faire marcher cette partition d'autant plus que je ne peux pas inclure un order by dans une sous requête.

    Merci

  4. #4
    Membre éclairé
    Inscrit en
    Septembre 2006
    Messages
    365
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 365
    Par défaut
    Bon je l'ai eu

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    select * from (select *, ROW_NUMBER() OVER (PARTITION BY H.categorie ORDER BY categorie, average_ventes desc) as N 
    from (
    	select R.categorie, R.article, count(R.ventes) as average_ventes
    	from (	select distinct categorie, article, ventes from ARTICLES a
    			join CATEGORIES c on a.article = c.article) R
    	group by R.categorie, R.article ) H ) as X
    where N <= 10
    order by X.categorie, X.average_ventes desc, N desc
    merci pour le tuyau..

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 04/09/2010, 12h07
  2. Les n premiers pour chaque groupe
    Par Sakalam dans le forum Langage SQL
    Réponses: 5
    Dernier message: 16/07/2007, 16h01
  3. Sélection du premier enregistrement de chaque groupe
    Par mout1234 dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 15/05/2007, 16h27
  4. Réponses: 2
    Dernier message: 07/03/2007, 16h30
  5. Requete pour obtenir les 25 premiers enregistrement
    Par dbizier dans le forum Oracle
    Réponses: 1
    Dernier message: 28/04/2006, 21h36

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