> 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
GratuitJeu PC Jagged Alliance Gold Edition gratuit
Valable jusqu'au 19 Septembre

Pour fête le 10ème anniversairee de THQ Nordic, Steam offre actuellement le jeu PC Jagged Alliance Gold Edition. Jagged Alliance est une véritable légende de la stratégie tactique au tour par tour. Jagged Alliance a eu un impact et a changé le genre de stratégie pour toujours. Vous pouvez maintenant découvrir cette légende sous sa forme originale glorieuse. Un appel à l'aide désespéré de l'île Metavira: le scientifique Jack Richards et sa charmante fille Brenda vous contactent. Les arbres en jachère et donc la précieuse sève médicale dont dépendent de nombreuses vies sont sous le contrôle du méchant et traître Santino. C'est pourquoi Jack et Brenda vous ont engagé, le commandant d'une force mercenaire, pour mettre un terme aux projets insensés de Santino.


> Voir l'offre
99,99 €Lit superposé métal 2x190x90 avec sommiers à 99,99 €
Valable jusqu'au 18 Septembre

Cdiscount fait une promotion sur le lit superposé (2 lits de 190 x 90 cm) Alice en métal qui passe à 99,99 € au lieu de 130 €. Equipé d’une échelle réversible, ce lit superposé convient aussi bien aux adultes, qu’aux enfants, et peut ainsi accueillir jusqu’à 120 kg. Les sommiers sont inclus et la livraison est gratuite.


> Voir l'offre
29,99 €Set de 6 Tournevis Bosch Professional à 29,99 €
Valable jusqu'au 19 Septembre

Amazon fait une promotion sur le set de 6 Tournevis Bosch Professional qui passe à 29,99 € au lieu de 39 €. 2x PH 125 mm, 1x PH 100 mm, 1x plat6,5 125 mm, 1x Plat5,5 100 mm, 1x Plat4,5 100 mm, 1x Plat3,5 75 mm.


> 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