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 :

comment calculer Max(count(*))


Sujet :

Requêtes MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Mars 2004
    Messages
    14
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2004
    Messages : 14
    Par défaut comment calculer Max(count(*))
    Pour quoi cette req. ne foctionne pas

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT n_dept,COUNT(*)
    FROM emp
    GROUP BY n_dept
    HAVING COUNT(*) = (SELECT MAX(COUNT(*))
                       FROM emp
                       GROUP BY n_dept) ;
    Merci

  2. #2
    Membre chevronné
    Homme Profil pro
    Développeur de jeux vidéo
    Inscrit en
    Mars 2006
    Messages
    400
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Développeur de jeux vidéo

    Informations forums :
    Inscription : Mars 2006
    Messages : 400
    Par défaut
    COUNT(*) compte le nombre d'élément dans un regroupement.
    MAX retourne le maximum dans un regroupement.
    Tu ne peux donc pas avoir les 2 imbriqués.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT n_dept,COUNT(*) as nb
    FROM emp
    GROUP BY n_dept
    HAVING nb = (SELECT COUNT(*) as n
                       FROM emp
                       GROUP BY n_dept ORDER BY n DESC LIMIT 1) ;
    En ordonnant les éléments par n, le maximum est le premier élément.
    Comme on ceux que ce maximum, on limite lies réultats à 1.

    Par ailleurs, lorsque qu'une requête ne fonctionne pas, pourrais-tu indiquer ce que retourne la requête (résultats ne correspondants pas aux attentes et/ou messages d'eurreurs).

  3. #3
    Membre chevronné
    Inscrit en
    Septembre 2006
    Messages
    685
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 685
    Par défaut
    C'est même pas obligé de faire une sous-requête, un order by devrait suffire.

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT n_dept, COUNT(*) AS nb
    FROM emp
    GROUP BY n_dept
    ORDER BY nb DESC LIMIT 1;

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

Discussions similaires

  1. Comment calculer la taille d'une base de données ?
    Par say dans le forum Décisions SGBD
    Réponses: 8
    Dernier message: 01/04/2011, 16h48
  2. [Matrices] Comment calculer le Déterminant d'une matrice 4x4
    Par cyber_N dans le forum Algorithmes et structures de données
    Réponses: 70
    Dernier message: 19/08/2005, 15h47
  3. comment calculer le temps d'execution
    Par passion_info dans le forum C++Builder
    Réponses: 1
    Dernier message: 09/06/2005, 09h13
  4. remplacer max(count())
    Par atog dans le forum Langage SQL
    Réponses: 2
    Dernier message: 07/01/2005, 00h01
  5. Réponses: 2
    Dernier message: 05/01/2005, 14h36

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