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

Access Discussion :

Utilisation du résultat de la ligne TOTAL dans une formule [AC-2007]


Sujet :

Access

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Mars 2014
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Service public

    Informations forums :
    Inscription : Mars 2014
    Messages : 13
    Points : 8
    Points
    8
    Par défaut Utilisation du résultat de la ligne TOTAL dans une formule
    *BONJOUR,*
    À partir d'une table contenant des demandes de services, je dois produire des statistiques sur les caractéristiques des utilisateurs. J'ai donc créé une requête qui extrait les informations désirées en ajoutant l'opération COMPTE sur le nombre de demandes et l'opération REGROUPEMENT sur le type de ménage. J'ai aussi ajouté une ligne TOTAL pour indiquer le nombre total de demandes de services. Voici le résultat de ma requête :

    Nb Demandes Ménages % Ménages
    1 Famille biparentale
    2 Célibataire-Colocataire
    2 Couple sans enfant
    4 Famille monoparentale
    9

    Afin de compléter ma requête, je dois calculer le pourcentage de représentation de chaque type de ménage. À titre d'exemple, les familles biparentales représentent 11,1%, soit 1 demande sur 9.

    Comment faire pour utiliser la valeur totale (9 dans mon exemple) dans le calcul de mon pourcentage?

    *MERCI.*

  2. #2
    Expert confirmé Avatar de nico84
    Homme Profil pro
    Consultant/développeur ERP
    Inscrit en
    Mai 2008
    Messages
    3 087
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant/développeur ERP
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2008
    Messages : 3 087
    Points : 5 203
    Points
    5 203
    Par défaut
    Bonjour,

    Avec une sous-requête (et une union pour le total en bas) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    select compte, type, count(*), count(*)/(select count(*) from matable) from matable group by compte
    union select 9, 'total', count(*), 1 from matable order by 1
    Utilisez Planet, gestion d'entreprise gratuite pour TPE / PME

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Mars 2014
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Service public

    Informations forums :
    Inscription : Mars 2014
    Messages : 13
    Points : 8
    Points
    8
    Par défaut
    Bonjour Nicolas,

    Malheureusement, mes connaissances en SQL sont très limitée et je ne vois pas comment régler mon problème. Voici le code SQL généré automatiquement par ma requête :

    SELECT DISTINCTROW Count(Demandes.[N° Demande]) AS [Nb Demandes], Utilisateurs.TypeMénage AS Ménages, FormatPercent([Ménages]/[Nb Demandes],1) AS [% Ménages]
    FROM Utilisateurs INNER JOIN Demandes ON Utilisateurs.[N° Utilisateur] = Demandes.Membre
    WHERE (((Demandes.DateDemande) Between #4/1/2013# And #3/31/2014#) AND ((Demandes.TypeDemande)=1 Or (Demandes.TypeDemande)=2))
    GROUP BY Utilisateurs.TypeMénage;

    Le champ [Nb Demandes] utilisé dans la fonction FormatPercent devrait être remplacé par un champ contenant le nombre total de demandes.

    Qu'est ce que je devrais ajouter à mon code SQL?

    Merci beaucoup...

  4. #4
    Futur Membre du Club
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Mars 2014
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Service public

    Informations forums :
    Inscription : Mars 2014
    Messages : 13
    Points : 8
    Points
    8
    Par défaut
    J'ai poursuivi mes recherches et voici le résultat :

    SELECT DISTINCTROW Count(Demandes.[N° Demande]) AS [Nb Demandes], Utilisateurs.TypeMénage AS Ménages, FormatPercent([Nb Demandes]/(SELECT DISTINCTROW Count(Demandes.[N° Demande]) FROM Demandes WHERE (((Demandes.DateDemande) Between #4/1/2013# And #3/31/2014#) AND ((Demandes.TypeDemande)=1 Or (Demandes.TypeDemande)=2))),1) AS [% Ménages]
    FROM Utilisateurs INNER JOIN Demandes ON Utilisateurs.[N° Utilisateur] = Demandes.Membre
    WHERE (((Demandes.DateDemande) Between #4/1/2013# And #3/31/2014#) AND ((Demandes.TypeDemande)=1 Or (Demandes.TypeDemande)=2))
    GROUP BY Utilisateurs.TypeMénage;

    Tout fonctionne correctement...

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 18/08/2009, 15h49
  2. Utiliser le résultat d'un fichier php dans fonction javascript
    Par theshark85 dans le forum Général JavaScript
    Réponses: 9
    Dernier message: 23/07/2009, 12h07
  3. Réponses: 6
    Dernier message: 25/03/2009, 01h50
  4. [TDC] XL200 - Utiliser TOTAL dans une formule
    Par crica dans le forum Excel
    Réponses: 1
    Dernier message: 04/12/2008, 13h29
  5. Réponses: 2
    Dernier message: 30/06/2008, 10h20

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