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

Langage SQL Discussion :

Calculer le rang centile


Sujet :

Langage SQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Inscrit en
    Octobre 2006
    Messages
    277
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 277
    Par défaut Calculer le rang centile
    Bonjour à vous,

    Je désire calculer le rang centile d'un étudiant en particulier.

    Si on prend un exemple plus simplifié de ma liste de données

    ID Note
    156232 6.5
    156233 6.5
    156237 6.5
    156238 7.0
    156234 8.5
    156239 9.5
    156236 10.5

    Si on calcule le rang centile de l'étudiant 156238 selon la formule :

    Nom : rang centile.PNG
Affichages : 4795
Taille : 5,6 Ko

    Cela donnerait : Rang centile 43

    Comment reproduire cela en SQL .

    Merci de votre aide, très apprécié.

  2. #2
    Membre émérite Avatar de bstevy
    Homme Profil pro
    Solutions Architect
    Inscrit en
    Mai 2009
    Messages
    552
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : Japon

    Informations professionnelles :
    Activité : Solutions Architect
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2009
    Messages : 552
    Par défaut
    Il suffit d'appliquer la formule:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    select 
    100*(
    (select count(*) from maTable where note < (select note from maTable where ID = 156238 ))
    +
    (select count(*) from maTable where note = (select note from maTable where ID = 156238 ))
    )
    /
    (select count(*) from maTable )
    Après, selon votre SGBD, la facon exact de faire ca peut changer.
    Mais l'idée est la.

  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
    Par défaut
    Bonjour,

    Votre résultat est faux : 100(3 + (1/2)) / 7 = 50 !

    si votre SGBDR le supporte, vous pouvez directement utiliser PERCENT_RANK

  4. #4
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 639
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 639
    Billets dans le blog
    10
    Par défaut
    2 remarques :
    - il manque la division par 2 dans le 2ème comptage de la requete de bstevy
    - il me semble que le résultat 50% est juste (et non 43%) puisque selon la définition :

    "Le rang centile d'une donnée indique le pourcentage des données ayant une valeur inférieure ou égale à la donnée considérée. Si le rang centile n'est pas un entier, on l'arrondit à l'entier supérieur."Ici on a donc 3,5 sur 7 ce qui fait bien 50% !

  5. #5
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    22 010
    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 010
    Billets dans le blog
    6
    Par défaut
    Il suffit d'utiliser directement la fonction de fenêtrage PERCENTILE_RANK().

    Lisez mon cours à ce sujet :
    http://sqlpro.developpez.com/article...e-window/#LIII

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

  6. #6
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 639
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 639
    Billets dans le blog
    10
    Par défaut
    Citation Envoyé par SQLpro Voir le message
    Il suffit d'utiliser directement la fonction de fenêtrage PERCENTILE_RANK().

    Lisez mon cours à ce sujet :
    http://sqlpro.developpez.com/article...e-window/#LIII

    A +
    Oui mais comme le SGBD n'est pas précisé et que tous les SGBD ne proposent pas cette fonction, la reponse de Bstevy est appropriée (sous réserve d'ajouter la division manquante bien sur)

Discussions similaires

  1. Calculer avec RANG
    Par Sylcoco dans le forum Excel
    Réponses: 2
    Dernier message: 16/03/2010, 15h19
  2. calcul du rang de correlation
    Par kazuzu dans le forum Débuter
    Réponses: 6
    Dernier message: 01/11/2009, 14h14
  3. [AC-2003] calcul du rang d'un étudiant dans sa classe
    Par dark_geek dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 09/05/2009, 18h52
  4. Calculer le range de Ix
    Par laziolb dans le forum OpenCV
    Réponses: 3
    Dernier message: 27/05/2008, 16h20
  5. Réponses: 6
    Dernier message: 25/09/2007, 15h29

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