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 :

Moyenne dans une colonne


Sujet :

Access

  1. #1
    Candidat au Club
    Inscrit en
    Janvier 2007
    Messages
    3
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 3
    Points : 2
    Points
    2
    Par défaut Moyenne dans une colonne
    Bonjour,

    Je suis sous access 2007.

    J'ai une table du genre :
    | N° | Date | Température |

    et j'aimerais par une requète obtenir quelque chose du genre :
    | N° | Date | Température | Moyenne |

    Ou "Moyenne" contient la moyenne de la colonne "Température" pour les dates
    inférieures ou égales à la date de la ligne en cours.

    J'essaie avec les fonctions d'agrégation mais j'avoue que je ne comprends pas très bien comment faire.

    Merci d'avance.

  2. #2
    Rédacteur/Modérateur

    Avatar de Heureux-oli
    Homme Profil pro
    Contrôleur d'industrie
    Inscrit en
    Février 2006
    Messages
    21 087
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 59
    Localisation : Belgique

    Informations professionnelles :
    Activité : Contrôleur d'industrie
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 21 087
    Points : 42 926
    Points
    42 926
    Par défaut
    Bonjour et bienvenue sur le forum Access de DVP.

    Les fonction agrégat devraient faire la moyenne.
    Si j'ai tout compris, tu veux que la moyenne soit inscrite dans la table, dans un champ pour chaque ligne ajoutée.

    Je te propose de calculer la moyenne après la mise à jour du champ température

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    Private Sub Temp_AfterUpdate()
    Moyenne = DAvg("[Temp]", "tblTemp")
    Debug.Print DAvg("[Temp]", "tblTemp")
    End Sub
    J'ai pas encore de décodeur, alors, postez en clair ! Comment mettre une balise de code ?
    Débutez en VBA

    Mes articles


    Dans un MP, vous pouvez me dire que je suis beau, ... mais si c'est une question technique je ne la lis pas ! Vous êtes prévenus !

  3. #3
    Expert confirmé

    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 419
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 419
    Points : 4 297
    Points
    4 297
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    SELECT a.numéro, a.date, a.température, Avg(b.température) AS MoyenneDetempérature
    FROM matable AS a, matable AS b
    WHERE (((b.date)<=[a].[date]))
    GROUP BY a.numéro, a.date, a.température;
    Elle est pas belle la vie ?

  4. #4
    Candidat au Club
    Inscrit en
    Janvier 2007
    Messages
    3
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 3
    Points : 2
    Points
    2
    Par défaut
    Ton truc à l'air de marcher impec ! Merci.

    Ceci dit, dans ton exemple, si je comprends le procédé consistant à créer deux alias d'une même table, je ne pige pas tout au sujet de la clause "group by"...

    Mais bon...j'essaierai de comprendre plus tard. Déjà ça marche !
    Merci encore.

  5. #5
    Expert confirmé

    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 419
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 419
    Points : 4 297
    Points
    4 297
    Par défaut
    Mon "truc" utilise une multiplication cartésienne.
    En clair, si je fais un sélect portant sur deux tables sans jointure entre elles
    j'obtiens l'ensemble des combinaisons possibles.
    Ici si j'enlève le group by je vais obtenir pour chaque numéro, sa date et sa température et aussi toutes les températures des dates inférieures et égales.

    le group by va me permettre d'obtenir un seul enregistrement par date.
    Elle est pas belle la vie ?

  6. #6
    Candidat au Club
    Inscrit en
    Janvier 2007
    Messages
    3
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 3
    Points : 2
    Points
    2
    Par défaut
    Ok! J'ai compris.

    Ca signifie donc que si je voulais inclure un autre champ provenant de ma table (par exemple "Lieu") dans ma requete, il faudrait que je "group by" N°, Date...etc...Lieu.

    Je présume qu'il y a d'autres méthodes que celle consistant à construire une requête à partir de "Table X Table" pour arriver à mes fins mais pour l'instant ce "truc" (pardon d'avoir usé d'une terminologie aussi triviale et de n'avoir pas invoqué Monsieur Descartes) marche bien pour moi.

    Merci derechef.

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

Discussions similaires

  1. calcul de moyenne sur plusieurs plages dans une colonne
    Par Jean-luc79 dans le forum Excel
    Réponses: 2
    Dernier message: 19/12/2014, 11h20
  2. Réponses: 8
    Dernier message: 26/08/2013, 18h36
  3. INTERBASE 5.5 insertion dans une colonne BLOB
    Par mariustrezor dans le forum Bases de données
    Réponses: 4
    Dernier message: 29/10/2004, 18h06
  4. Noms de colonne dans une colonne
    Par Digirom dans le forum Langage SQL
    Réponses: 14
    Dernier message: 23/04/2004, 11h51
  5. intervertir les valeurs dans une colonne d'une table
    Par hammou dans le forum Débuter
    Réponses: 2
    Dernier message: 26/01/2004, 10h15

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