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 :

#1111 - Invalid use of group function


Sujet :

Requêtes MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juillet 2006
    Messages
    985
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juillet 2006
    Messages : 985
    Par défaut #1111 - Invalid use of group function
    Slt à tous,
    J'ai cette requete :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    SELECT CONCAT(dl.id_legis, ' - ', 
    			COUNT(dl.id_depute), ' - ', 
    			GROUP_CONCAT(DISTINCT CONCAT(s.genre, '(',  ')') ORDER BY s.genre SEPARATOR ", ")
    	   ) as legislatures
    FROM depute_legislatures as dl
    INNER JOIN membres as m ON m.id_membre = dl.id_depute
    INNER JOIN sexe as s ON s.id_sexe = m.sexe
    WHERE dl.suppleant = 0
    GROUP BY dl.id_legis
    ORDER BY dl.id_legis
    et un jeu de résultat
    legislatures
    1 - 120 - Féminin(), Masculin()
    2 - 120 - Féminin(), Masculin()
    3 - 120 - Féminin(), Masculin()
    4 - 180 - Féminin(), Masculin()
    5 - 180 - Féminin(), Masculin()
    6 - 180 - Féminin(), Masculin()
    7 - 180 - Féminin(), Masculin()
    8 - 180 - Féminin(), Masculin()
    Ce résultat est satisfaisant.
    Explication de chaque ligne : La législature 1 compte 120 députés constitués de Féminin() pour femmes et Masculin() pour hommes.

    Je souhaite maintenant entre les parenthèses de chaque genre ajouter le nombre de députés dans ce genre.
    Exemple :
    legislatures
    1 - 120 - Féminin(10), Masculin(110)
    2 - 120 - Féminin(8), Masculin(112)
    Pour le résultat ci-dessus, je modifie ma requête ainsi :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    SELECT CONCAT(dl.id_legis, ' - ', 
    		       COUNT(dl.id_depute), ' - ', 
    		       GROUP_CONCAT(DISTINCT CONCAT(s.genre, '(', CAST(COUNT(dl.id_depute) AS CHAR), ')') ORDER BY s.genre SEPARATOR ", ")
    	   ) as legislature
    FROM depute_legislatures as dl
    INNER JOIN membres as m ON m.id_membre = dl.id_depute
    INNER JOIN sexe as s ON s.id_sexe = m.sexe
    WHERE dl.suppleant = 0
    GROUP BY dl.id_legis, m.sexe
    ORDER BY dl.id_legis
    Modifications :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    // Ajout de CAST(COUNT(dl.id_depute) AS CHAR)
    GROUP_CONCAT(DISTINCT CONCAT(s.genre, '(', CAST(COUNT(dl.id_depute) AS CHAR), ')') ORDER BY s.genre SEPARATOR ", ")
    et
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    // Ajout  m.sexe
    GROUP BY dl.id_legis, m.sexe
    Et j'ai gentiment comme erreur :
    #1111 - Invalid use of group function
    J'ai péché à quel niveau ?

    Merci d'avance...

  2. #2
    Membre éprouvé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juillet 2006
    Messages
    985
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juillet 2006
    Messages : 985
    Par défaut
    Ce que je souhaite faire est impossible? certains me diront de le faire avec un langage serveur comme PHP, moi je souhaite faire mes requete depuis une interface PhpMyAdmin.

    Merci d'avance...

  3. #3
    Membre éprouvé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juillet 2006
    Messages
    985
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juillet 2006
    Messages : 985
    Par défaut
    Compte tenu du manque de réaction, je déduits que c'est de la cosmétique.

    Meilleures salutations à tous...

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

Discussions similaires

  1. Invalid use of group function
    Par okoweb dans le forum Requêtes
    Réponses: 1
    Dernier message: 05/02/2011, 23h36
  2. Cannot use an aggregate function in a GROUP BY clause
    Par MICLANG dans le forum Firebird
    Réponses: 4
    Dernier message: 16/08/2010, 17h29
  3. invalid use of group function
    Par Invité dans le forum Requêtes
    Réponses: 2
    Dernier message: 22/09/2008, 21h07
  4. UPDATE et AVG(): invalid use of group function
    Par ctobini dans le forum Requêtes
    Réponses: 1
    Dernier message: 27/02/2008, 12h12
  5. invalid use of group function
    Par sirbaldur dans le forum Requêtes
    Réponses: 1
    Dernier message: 10/05/2006, 14h38

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