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 :

Calcul de médiane


Sujet :

Langage SQL

  1. #1
    Inactif  
    Homme Profil pro
    Inscrit en
    Novembre 2012
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2012
    Messages : 22
    Points : 18
    Points
    18
    Par défaut Calcul de médiane
    Bonjour

    Je cherche à calculer une durée médiane mais il s'avère que mon problème est un peu compliqué.
    Je vous explique :

    J'ai une table avec des numéros de tickets et une durée en seconde.
    Exemple :

    Id_ticket durée
    1 620
    2 190
    3 880
    4 320
    5 250
    6 500
    7 600
    8 1200

    Dans une autre table, j'ai le numéro d'un utilisateur qui est associé au ticket
    Exemple :

    Id_Utilisateur Id_Ticket
    11 1
    11 7
    11 8
    11 3
    33 4
    33 5
    49 2
    49 6

    (bien entendu, la base de données est beaucoup plus fournie que cela)

    Je voudrais avoir la durée médiane pour chaque employé.

    Merci d'avance pour votre aide

  2. #2
    Membre expert
    Avatar de alassanediakite
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2006
    Messages
    1 599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Mali

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2006
    Messages : 1 599
    Points : 3 591
    Points
    3 591
    Billets dans le blog
    8
    Par défaut
    Salut
    Que veux-tu dire par "médiane"?
    La moyenne arithmétique (somme des durées divisée par le nombre de tickets)? ou la durée (de ticket) la plus proche de la moyenne arithmétique?
    Pour le premier...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT utilisateur.idutilisateur, avg(ticket.duree) FROM utilisateur INNER JOIN ticket on utilisateur.idticket=ticket.idticket Group by utilisateur.idutilisateur
    Pour le deuxième cela peut-être un peu compliqué mais si c'est le but je pourrais essayer de m'arracher quelques cheveux.
    @+

  3. #3
    Inactif  
    Homme Profil pro
    Inscrit en
    Novembre 2012
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2012
    Messages : 22
    Points : 18
    Points
    18
    Par défaut
    Et non la moyenne c'est simple. Ce que je souhaite c'est la médiane.

    C'est-à-dire que je cherche la durée x où 50% des durées sont supérieures à x et 50% inférieures à x.

    Je m'arrache les cheveux depuis vendredi, alors si quelqu'un arrive à me filer un coup de main ce serait génial.

    Merci d'avance

  4. #4
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 034
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 034
    Points : 23 779
    Points
    23 779
    Par défaut
    Bonjour,

    Quel est votre SGBD ?

  5. #5
    Inactif  
    Homme Profil pro
    Inscrit en
    Novembre 2012
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2012
    Messages : 22
    Points : 18
    Points
    18
    Par défaut
    En effet j'ai oublié de précisé mon SGBD. Il s'agit de MySQL.

    Merci

  6. #6
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 034
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 034
    Points : 23 779
    Points
    23 779
    Par défaut
    Bon, alors essaie la requête suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    SELECT id_user, AVG(duree) AS median
    FROM (
    	SELECT tu.id_user, t.duree
    	FROM ticket_user tu
    	INNER JOIN ticket t ON tu.id_ticket = t.id_ticket
    	INNER JOIN ticket_user tu2 ON tu.id_user = tu2.id_user
    	INNER JOIN ticket t2 ON tu2.id_ticket = t2.id_ticket
    	GROUP BY tu.id_user, t.duree
    	HAVING SUM(CASE WHEN t.duree = t2.duree THEN 1 ELSE 0 END) >= ABS(SUM(SIGN(t.duree - t2.duree)))
    ) AS tab
    GROUP BY id_user
    ORDER BY id_user;
    J'ai appelé la première table (dans ton exemple initial) ticket et la deuxième ticket_user.

  7. #7
    Inactif  
    Homme Profil pro
    Inscrit en
    Novembre 2012
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2012
    Messages : 22
    Points : 18
    Points
    18
    Par défaut
    Merci ced

    Je l'adapte, je le teste et je te dis si c'est bon.


  8. #8
    Inactif  
    Homme Profil pro
    Inscrit en
    Novembre 2012
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2012
    Messages : 22
    Points : 18
    Points
    18
    Par défaut
    Tout à l'air de bien fonctionner!

    Merci beaucoup ced

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

Discussions similaires

  1. Calculer une médiane
    Par Au pays des stats dans le forum SAS STAT
    Réponses: 9
    Dernier message: 18/05/2012, 13h22
  2. Arbre ORB et calcul de médiane
    Par Heimdall dans le forum Programmation parallèle, calcul scientifique et de haute performance (HPC)
    Réponses: 0
    Dernier message: 16/01/2012, 23h30
  3. [AC-2000] Erreur "ByRef" pour un calcul de Médiane
    Par Cantalou dans le forum VBA Access
    Réponses: 16
    Dernier message: 24/11/2009, 12h47
  4. Stat calculer : Quartile ? Médiane ? ...
    Par Beamish dans le forum Access
    Réponses: 8
    Dernier message: 01/12/2005, 15h33

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