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

PHP & Base de données Discussion :

Comment calculer la moyenne d'une variable récupére d'un champ mysql [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    69
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 69
    Points : 46
    Points
    46
    Par défaut Comment calculer la moyenne d'une variable récupére d'un champ mysql
    Bonjour,
    comment peut on calculer la moyenne d'une variable récupérer avec une boucle WHILE provenant d'un champ d'une base mysql sans utiliser AVG.

    Ex:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    .
    .
    $SQL = "SELECT * FROM table WHERE var ORDER BY date ASC";
    $result = mysql_query($SQL) ;
    .
    .
    .
    $i=0;
       while($row = mysql_fetch_row($result)) 
          {
        if ($i==0)
        $i=$i+1;
    Ce code fonctionne et affiche correctement le contenu de la variable $var ligne par ligne, comme ceci:

    30
    40
    10

    Je souhaite en plus ajouter la moyenne de la liste affichée ci-dessus
    comme ceci:

    30
    40
    10
    moy: 26.66

    Donc, je cherche une solution pour cas à chaque boucle while je récupère le contenu de la variable $var pour en calculer la moyenne lorsque la boucle while est terminée.
    (Je ne veut pas utiliser la fonction AVG (mysql) car dans la variable $var n'est pas forcément un nombre, mais des fois un valeur à laquelle j'attribue une valeur et cette valeur va dans $var)
    Si vous avez une idée sur une solution, merci à vous

  2. #2
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 048
    Points
    34 048
    Billets dans le blog
    14
    Par défaut
    Vraiment pas clair ton besoin !

    Pour moi, l'incrémentation de $i ne se produira qu'une fois. Je ne vois donc pas comment tu obtiens les valeurs 30, 40, 10.

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    69
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 69
    Points : 46
    Points
    46
    Par défaut
    Il m'affiche autant de ligne qu'il trouve dans la base de données, mais ca, ca fonctionne, c'est de récupérer toutes ces lignes pour en faire la moyenne

  4. #4
    Membre expérimenté Avatar de riete
    Homme Profil pro
    DevWeb - Oléiculteur
    Inscrit en
    Avril 2006
    Messages
    1 193
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France

    Informations professionnelles :
    Activité : DevWeb - Oléiculteur
    Secteur : Bâtiment

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 193
    Points : 1 414
    Points
    1 414
    Par défaut
    Il faut juste avoir une variable temporaire qui cumule tes valeurs et à la sortie du while diviser cette valeur par $i. Quelque chose comme ça.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    $i=0;
    $t = 0;
       while($row = mysql_fetch_row($result)) {
        $i++;
        $t += $row['var'];
       }
    $moyenne = $t/$i;

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    69
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 69
    Points : 46
    Points
    46
    Par défaut
    Merci, c'est impeccable !

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

Discussions similaires

  1. [PDO] Mise en correspondance d'une variable et d'un champ Mysql
    Par FrankH dans le forum PHP & Base de données
    Réponses: 17
    Dernier message: 22/01/2014, 20h14
  2. 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
  3. Comment calculer la moyenne sur une colonne selon un critère
    Par Contact2012 dans le forum Requêtes
    Réponses: 3
    Dernier message: 18/06/2010, 16h07
  4. [XSL] Comment modifier la valeur d'une variable?
    Par sorcer1 dans le forum XSL/XSLT/XPATH
    Réponses: 8
    Dernier message: 17/02/2010, 13h26
  5. Réponses: 3
    Dernier message: 05/04/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