> Tous les forums > Forum des Webmasters
 MySQL - somme des valeurs d'un champs [->Résolu
Ajouter un message à la discussion
Page : [1] 
Page 1 sur 1
Rolive
  Posté le 23/10/2004 @ 10:51 
Aller en bas de la page 
Petit astucien
Bonjour, Je développe un système de notation et je souhaiterai pouvoir afficher la moyenne des notes pour les enregistrements d'une table x. Une table y contenant les notes fait la relation entre les différents votes des membres avec l'id de l'enregistrement associé de la table x et autre champs dans la table y associe chaque module de votes à une section x ou y pour n'avoir en fait qu'une unique table pour tout les modules de votes. Avec un classement par section, chacun des modules sont totalement indépendants tout en étant sur une seule table. J'espère m'être bien expliqué. bref, ma requête pour calculer le nombre de votes est du style : [code]<? $query="SELECT * FROM user_notes WHERE section = '$section' AND module_id = '$id'"; // $id = la page qui est notée $nb_votes=@mysql_num_rows(@mysql_query($query)); ?>[/code] Ensuite, je voudrais faire une requête calculant la somme totale des valeurs contenues dans le champs note où sont en fait enregistrées tout les votes allant de 0 pour la note la plus basse jusqu'à 10 la plus élevée. Le calcul serait : [code]<? $val_moyenne=(($somme_des_votes / $nb_votes); ?>[/code] Par ex imaginons que la table contienne 4 votes : 2,4,6,8 [code]<? $somme_des_votes=(2+4+6+8); ?>[/code] ($somme_des_votes/4) soit une moyenne de 5. Comment construire la requête SQL pour calculer la $somme_des_votes ?

Modifié par Rolive le 23/10/2004 13:28
Publicité
nono21
 Posté le 23/10/2004 à 12:33 
Aller en bas de la page Revenir au message précédent Revenir en haut de la page
Petit astucien
Bonjour, pour calculer la somme, tu fais la requete SELECT SUM(note) AS somme FROM nom_de_la_table WHERE ... pour récupérer la valeur, $resultat=mysql_fetch_array(mysql_query($requete)); et $somme=$resultat[somme]; Mais tu peux calculer directement la moyenne par le mysql, sans t'emm... à calculer la somme et le nombre de notes, A la place de SUM tu mets AVG et tu fais exactement pareil
Rolive
 Posté le 23/10/2004 à 12:53 
Aller en bas de la page Revenir au message précédent Revenir en haut de la page
Petit astucien
Bonjour mono21 Merci ! [smile] Je vais faire ce que tu m'a dit et je reviens te dire si c'est bon ! Merci beaucoup [smile]
nono21
 Posté le 23/10/2004 à 12:58 
Aller en bas de la page Revenir au message précédent Revenir en haut de la page
Petit astucien
De rien, bon courage J'ajoute que pour compter le nombre de notes, tu peux faire pareil mais avec COUNT(user_notes) au lieu de SUM, car avec ton SELECT * si ta table est importante, ça va prendre beaucoup de temps zu serveur. Il vaut mieux faire faire le max de travail par mysql
Rolive
 Posté le 23/10/2004 à 13:20 
Aller en bas de la page Revenir au message précédent Revenir en haut de la page
Petit astucien
Yes, ça marche nickel ! Merci beaucoup nono [smile] J'ai fais des tests en votant avec deux comptes différents car j'ai limité les votes à un par membre et par module. La moyenne est bien calculée ! Merci aussi pour ton conseil, pour l'instant la table ne contient que 4 enregistrements. Mon site est en construction j'ai encore le temps avant qu'elle n'atteigne 200 votes et+ [crazy] J'ai commençé le site fin juillet et je n'en vois pas la fin! [boom]
Rolive
 Posté le 23/10/2004 à 13:29 
Aller en bas de la page Revenir au message précédent Revenir en haut de la page
Petit astucien
Merci encore nono Bon week-end ! [clindoeil]
Page : [1] 
Page 1 sur 1

Vous devez être connecté pour participer à la discussion.
Cliquez ici pour vous identifier.

Vous n'avez pas de compte ? Créez-en un gratuitement !
Recevoir PC Astuces par e-mail


La Lettre quotidienne +226 000 inscrits
Avec l'actu, des logiciels, des applis, des astuces, des bons plans, ...

Les bonnes affaires
Une fois par semaine, un récap des meilleurs offres.

Les fonds d'écran
De jolies photos pour personnaliser votre bureau. Une fois par semaine.

Les nouveaux Bons Plans
Des notifications pour ne pas rater les bons plans publiés sur le site.

Les bons plans du moment PC Astuces

Tous les Bons Plans
3 pour 23 produits Lego achetés = le moins cher offert
Valable jusqu'au 27 Septembre

Pour l'achat de 3 produits LEGO parmi une sélection, Cdiscount vous offre immédiatement le moins cher grâce au code promo LEGOFDAYS21.


> Voir l'offre
Les French Days chez Cdiscount
Valable jusqu'au 27 Septembre

Cdiscount participe aux French Days et fait des milliers de promotions imbattables. De plus vous pourrez obtenir 20 € de réduction à partir de 299 € d'achats avec le code promo 20EUROS.


> Voir l'offre
32,90 €Disque dur Seagate BarraCuda 1 To à 32,90 €
Valable jusqu'au 27 Septembre

Cdiscount propose actuellement le disque dur Seagate BarraCuda - 1 To (ST1000DM010) à 32,90 €On le trouve ailleurs autour de 42 €. Ce disque dur 3.5 pouces SATA III tourne à 7200tr/min et possède 64Mo de cache. Notez que la version 2 To est également en promotion à 44,99 €.


> Voir l'offre

Sujets relatifs
tester un champs mysql
Considérer un champs vide mysql non null
rajout données ds champs mysql
test champs base mysql
Wrong parameter count for mysql ==> resolu
PHP/MySQL: count () plusieurs champs
Accès distant à Mysql [RESOLU]
récuperer des valeurs en boucle (php)resolu
[RESOLU]Souci création de table sur MYSQL avec err
MySQL sur CEGETEL - Résolu
Plus de sujets relatifs à MySQL - somme des valeurs d''un champs [->Résolu
 > Tous les forums > Forum Forum des Webmasters