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 :

formule de calcul sur des données d'un meme champs


Sujet :

Access

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    44
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 44
    Points : 19
    Points
    19
    Par défaut formule de calcul sur des données d'un meme champs
    Rappel : Je débute et je prends gout à Access ... Reponse sans langage VBA ... histoire de ne pas me decourager ....

    Est ce qu'une ame sympathique peut me donner la formule à mettre dans le champs de la requete sur la base des information suivante :

    J'ai une table dans laquelle, il y a 2 champs :


    DateRel IndexRel
    15/11/03 150
    15/11/03 130
    15/11/03 90
    15/11/03 35
    18/11/04 160
    18/11/04 135
    18/11/04 97
    18/11/04 42

    Il me faut calculer une consommation : celle ci est egale à la difference entre indexRel du 15/11/04 - l'indexRel 15/11/03

    Le p'tit plus : mais j'aurais aimé que l'application demande à l'utilisateur : Quel relevé souhaitez vous ?

    Merci beaucoup

  2. #2
    Expert éminent sénior
    Avatar de Dolphy35
    Homme Profil pro
    Responsable Systemes d'Information
    Inscrit en
    Octobre 2004
    Messages
    4 373
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Responsable Systemes d'Information
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2004
    Messages : 4 373
    Points : 11 218
    Points
    11 218
    Par défaut
    Salut,

    Tu peux faire cela dan une requête.

    Dans le Champs DateRel tu met une formule du Style => >=#15/11/2003# AND <=#15/11/2004#.

    Et tu fais une Somme sur IndexRel.

    Tout cela tu le fais dans l'éditeur de Requête.

    @+

  3. #3
    Membre confirmé
    Avatar de Petogaz
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    479
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 479
    Points : 580
    Points
    580
    Par défaut
    salut,

    Citation Envoyé par Luc01
    Il me faut calculer une consommation : celle ci est egale à la difference entre indexRel du 15/11/04 - l'indexRel 15/11/03
    dans la table que tu présente il n'y a pas d'indexRel correspondant à la date 15/11/04 . est ce normal ?
    on ne voit aucune date correspondant à l'exemple que tu donne. donc je n'ai toujours pas compris ta question.

  4. #4
    Membre à l'essai
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    44
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 44
    Points : 19
    Points
    19
    Par défaut
    Effectivement, tu as raison

    Je paufine ma question et ma table :

    DateRel - IndexRel - NumCompteur
    15/11/03 - 150 - 1
    15/11/03 - 130 - 2
    15/11/03 - 90 - 3
    15/11/03 - 35 - 4
    18/11/04 - 160 - 1
    18/11/04 - 135 - 2
    18/11/04 - 97 - 3
    18/11/04 - 42 - 4
    17/11/05 - 175 - 1
    17/11/05 - 140 - 2
    17/11/05 - 100 - 3
    17/11/05 - 48 - 4
    et ainsi de suite pour 2006, 2007 ...

    la consommation du NumCompteur est egale à la difference entre indexRel de 2 dates cad : IndexRel du 18/11/04 - l'indexRel du 15/11/03 ou indexRel du 17/11/04 et IndexRel du 18/11/04

    C'est pour cela que j'aurais aimé que l'application pose une question "Quelle sont les dates de l'intervalle ?"
    et que la formule prenne en consideration les date de l'utilisateur

    J'espere etre plus clair
    Merci

    PS : Desolé mais je ne maitrise pas encore le generateur des formules ....

  5. #5
    Membre confirmé
    Avatar de Petogaz
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    479
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 479
    Points : 580
    Points
    580
    Par défaut
    il y a encore une chose que je ne comprend pas. dans quelle logique tu prend deux champs et tu fais la soustraction. sachant qu'il y a des dates identiques dans ton champ date. faut-il commencer par faire un regroupement sur les dates identiques et additionner les compteurs pour n'avoir qu'une ligne pour chaque date et enfin procéder au calcul de la consommation ? à toi de nous dire.

  6. #6
    Expert éminent sénior
    Avatar de Dolphy35
    Homme Profil pro
    Responsable Systemes d'Information
    Inscrit en
    Octobre 2004
    Messages
    4 373
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Responsable Systemes d'Information
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2004
    Messages : 4 373
    Points : 11 218
    Points
    11 218
    Par défaut
    Salut Petogaz,

    Je pense que les mêmes dates sont dissociées par NumCompteur.

  7. #7
    Nouveau membre du Club
    Inscrit en
    Novembre 2005
    Messages
    33
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 33
    Points : 33
    Points
    33
    Par défaut
    Salut et bonne année à tous
    S'il s'agit d'un calcul de consommation par compteur
    Je te propose de réaliser 3 requêtes
    1- une requête rq1 qui te renvoie le les relevés de départ

    PARAMETERS [date début] DateTime;
    SELECT Table.date, Table.relevé, Table.compteur
    FROM Table
    WHERE (((Table.date)=[date début]));

    2 - une requête rq2 qui te renvoie les relevés finaux :

    PARAMETERS [date fin] DateTime;
    SELECT Table.date, Table.relevé, Table.compteur
    FROM Table
    WHERE (((Table.date)=[date fin]));

    3 - et enfin la dernière requête qui calcule les conso :
    SELECT rq1.compteur, rt1.date AS dt1, rq2.date AS dt2, rq1.relevé AS relevé1, rq2.relevé AS relevé2, [relevé1]-[relevé2] AS conso
    FROM rq1 INNER JOIN rq2 ON rq1.compteur = rq2.compteur;


    Si tu veux une consommation globale, il faudra faire un regroupement avec les 3 champs: relevé1 et relevé2 (somme) et conso : expression.

    En espérant avoir pu t'aider

  8. #8
    Membre à l'essai
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    44
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 44
    Points : 19
    Points
    19
    Par défaut
    Je t'explique ...

    Chaque année (vers le 15/11), il y a un relevé d'index des compteurs d'eau (il y a 140 compteurs) repartie entre Ec et EF (eau chaude et Froide).

    Le NumCompteur est donc le numéro du compteur lequel appartient à un Appartement, lequel Appartement appartient à un proprio.

    Il me faut donc calculer la consommation de chaque compteur (difference des index entre 2 dates) et cette consommation me sert pour le calcul du prix d'eau chaude et d'eau foide que le copro paiera dans ses charges.

    Merci

  9. #9
    Membre à l'essai
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    44
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 44
    Points : 19
    Points
    19
    Par défaut
    A Kryssy :

    Merci mais je debute et je ne comprends pas encore ce langage ... est ce abuser de ma part de te demander ce que je dois mettre dans les champs de chaque requete ?

    D'avance je te remercie

  10. #10
    Expert éminent sénior
    Avatar de Dolphy35
    Homme Profil pro
    Responsable Systemes d'Information
    Inscrit en
    Octobre 2004
    Messages
    4 373
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Responsable Systemes d'Information
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2004
    Messages : 4 373
    Points : 11 218
    Points
    11 218
    Par défaut
    Citation Envoyé par kryssy
    3 - et enfin la dernière requête qui calcule les conso :
    SELECT rq1.compteur, rt1.date AS dt1, rq2.date AS dt2, rq1.relevé AS relevé1, rq2.relevé AS relevé2, [relevé1]-[relevé2] AS conso
    FROM rq1 INNER JOIN rq2 ON rq1.compteur = rq2.compteur;
    Désole kryssy mais tu as deux petites erreurs dans ton code sur la 3ème requête tu as tapé rt1 au lieu rq1 et dans le calcul si il veut la conso c'est le relevé2 - le relevé1. Sinon ça fonctionne très bien

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT rq1.compteur, rq1.date AS dt1, rq2.date AS dt2, rq1.relevé AS relevé1, rq2.relevé AS relevé2, [relevé2]-[relevé1] AS conso
    FROM rq1 INNER JOIN rq2 ON rq1.compteur = rq2.compteur;
    Si tu ne veux pas taper de code ce système de 3 requêtes fonctionne très bien.

    Tu peux coller directement les codes que t'a mis dans ta requête en mode SQL tu n'a plus qu' à changer le nom de la table en fonction de la tienne et les noms des champs.

    @+

  11. #11
    Nouveau membre du Club
    Inscrit en
    Novembre 2005
    Messages
    33
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 33
    Points : 33
    Points
    33
    Par défaut
    dans la requête 1 basée sur la table
    met les 3 champs date, relevé et compteur
    avec pour le champ date le critère [date début] (paramètre de la requête)

    idem pour la requête 2 comme avec critère [date fin] au lieu de [date début]

    pour la requête 3 basée sur les reqête 1 et 2 liées entre elle par le champ compteur :
    les champs :
    - compteur de requête 1
    - relevé 1:relevé de requête 1
    - relevé 2:relevé de requête 2
    - conso : [relevé2] - [relevé1]

  12. #12
    Nouveau membre du Club
    Inscrit en
    Novembre 2005
    Messages
    33
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 33
    Points : 33
    Points
    33
    Par défaut
    Merci à dolphy 35 pour tes corrections

  13. #13
    Membre à l'essai
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    44
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 44
    Points : 19
    Points
    19
    Par défaut
    Merci à vous 2 ... c'est super, je m'en suis sorti ... avec des copier coller et en me payant le luxe de certaines modif sur la qestion de laRq1 et Rq2 (au lieu de rentrer des dates, plutot fastidieux, je rentre des codes, 1,2,3 ... qui correspondent aux dates ... et bien utiles pour les 15000 essais que je devrai faire avant que cette petite aplication fonctionne comme je le souhaite !!!


    A force de copier-coller ... j'ai aussi un peu compris la formulation SQL (pour ce cas là bien sur !!!) !!!!!

    Merci encore, sympa !!!

Discussions similaires

  1. Réponses: 4
    Dernier message: 08/04/2008, 16h41
  2. calcul sur des cases à cocher
    Par karidrou dans le forum Access
    Réponses: 3
    Dernier message: 06/12/2005, 11h40
  3. Réponses: 5
    Dernier message: 13/07/2005, 10h03
  4. Travailler sur des données qui doivent être triées
    Par haypo dans le forum XML/XSL et SOAP
    Réponses: 2
    Dernier message: 19/07/2003, 17h13
  5. Réponses: 4
    Dernier message: 15/12/2002, 04h19

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