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

Requêtes MySQL Discussion :

Requête avec SUM, LIMIT et ORDER


Sujet :

Requêtes MySQL

  1. #1
    Membre à l'essai
    Homme Profil pro
    Webmaster
    Inscrit en
    Octobre 2013
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Webmaster
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2013
    Messages : 4
    Par défaut Requête avec SUM, LIMIT et ORDER
    Bonjour,

    Une requête me pose problème. Je dois faire un classement de pilote suivant des résultats en ne prenant que les 10 meilleurs résultats par pilote.

    Exemple de la table :

    race_result_race_id - race_result_driver_id - race_result_rank - race_result_points
    2523 - 7464 - 1 - 1036
    2523 - 6464 - 2 - 936
    2523 - 7464 - 1 - 1036
    2523 - 6464 - 2 - 936
    2924 - 7464 - 12 - 322
    2924 - 6464 - 13 - 222
    3062 - 7464 - 17 - 245
    3062 - 6464 - 18 - 145

    J'aimerai avoir ce résultat classé par la SUM de race_result_points (LIMIT à 10 résultats par pilote ORDER BY race_result_points DESC) :
    race_result_driver_id - SUM(race_result_points)
    7464 - 2639
    6464 - 2239

    Je connais une requête (ci-dessous) qui fonctionne mais qui ne me sort que 1 seul pilote (une ligne)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT race_result_driver_id, SUM(race_result_points) AS race_result_sum 
    FROM (
    SELECT race_result_driver_id, race_result_points FROM race_result 
    JOIN race ON race.race_id=race_result.race_result_race_id 
    WHERE race_date LIKE "2012%" AND race_category_id=1 AND race_result_driver_id!=0 
    ORDER BY race_result_points DESC LIMIT 10
    ) AS a

    Des idées ?
    Merci d'avance

  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
    22 002
    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 : 22 002
    Billets dans le blog
    6
    Par défaut
    LIMIT n'existe pas en SQL. C'est spécifique à un SGBDR non normatif.

    En SQL vous devez faire un RANK() ou DENSE_RANK() à l'aides des fonctions fenêtrées. A lire : http://sqlpro.developpez.com/article...clause-window/

    En sus l'opérateur DIFFERENT DE s'exprime par <> et non par !=.

    Puis filtrer dans une sous requête en table dérivée (ou CTE), le rang.

    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 à l'essai
    Homme Profil pro
    Webmaster
    Inscrit en
    Octobre 2013
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Webmaster
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2013
    Messages : 4
    Par défaut
    Je travail sur MySQL 5. Je me suis trompée de catégorie peut être ?

  4. #4
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    22 002
    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 : 22 002
    Billets dans le blog
    6
    Par défaut
    Non, c'est moi... Désolé !

    Notez que le résultat avec LIMIT sera probablement faux.....

    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/ * * * * *

  5. #5
    Membre émérite Avatar de ypcman
    Homme Profil pro
    Retraité codeur !
    Inscrit en
    Janvier 2011
    Messages
    601
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Retraité codeur !
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Janvier 2011
    Messages : 601
    Par défaut
    Pour que le SUM somme plusieurs enregistrements, ne faut-il pas les grouper, ici par pilote ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    AS a GROUP BY race_result_driver_id

Discussions similaires

  1. Requête avec SUM, LIMIT et ORDER
    Par DesTVTS dans le forum Requêtes
    Réponses: 3
    Dernier message: 15/10/2013, 12h42
  2. PB Pourcentage Sur requête avec SUM et GROUP BY
    Par laetus dans le forum Langage SQL
    Réponses: 9
    Dernier message: 11/06/2009, 14h18
  3. Requêt avec sum ne donne pas le bon résultat§
    Par _cece dans le forum Langage SQL
    Réponses: 10
    Dernier message: 04/11/2008, 18h53
  4. requête avec SUM
    Par jeanfi77 dans le forum Requêtes
    Réponses: 1
    Dernier message: 07/05/2007, 18h03
  5. [SQLServer] Requête avec SUM
    Par FzF dans le forum Langage SQL
    Réponses: 3
    Dernier message: 18/05/2006, 16h19

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