Précédent   Forum des professionnels en informatique > PHP > PHP & SGBD > PHP & MySQL
PHP & MySQL Forum d'entraide sur les fonctions MySQL avec PHP. Avant de poster -> FAQ MySQL, Cours MySQL et Sources MySQL. Pour les questions concernant le moteur MySQL plutôt que les fonctions PHP, merci d'utiliser le forum MySQL.
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 18/10/2011, 13h32   #1
Invité de passage
 
Inscription : septembre 2006
Messages : 13
Détails du profil
Informations forums :
Inscription : septembre 2006
Messages : 13
Points : 2
Points : 2
Par défaut Requête pour compter sur 3 tables

Bonjour,
Je dois réaliser une requête sur ces 3 tables :

participants(num_participant,nom, prenom, ...)
inscriptions(num_inscription, num_participant, num_activite, presence,...)
activites(num_activite, designation, type, date,...)

on me demande de réaliser un hit-parade des participants avec le nombre d'inscriptions.

voici ou je suis arrêté avec la requête :
Code :
1
2
3
4
5
6
7
 
SELECT participants.num_participant, participants.nom, participants.prenom
 FROM participants
 INNER JOIN inscriptions ON inscriptions.num_participant = participants.num_participant
 INNER JOIN activites ON activites.num_activite = inscriptions.num_activite
 ORDER BY participants.nom
 LIMIT 0 , 30
Voici le résultat :



On se rapproche de l'objectif, reste à compter pour chaque participants en partant de celui qui a le plus d'inscriptions:

Addoun : 6
Aarab : 5
Abboudi : 1
Abras : 1

Je pense à COUNT et GROUP BY mais je nage un peu, je vais des tests.

Avez-vous une piste de solutions ?

Merci +++

Nicolas
nicodespiennes est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/10/2011, 14h52   #2
Modérateur
 
Avatar de CinePhil
 
Homme Philippe Leménager
Ingénieur d'études en informatique
Inscription : août 2006
Messages : 11 029
Détails du profil
Informations personnelles :
Nom : Homme Philippe Leménager
Âge : 48
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 : 11 029
Points : 18 328
Points : 18 328
Envoyer un message via MSN à CinePhil
Citation:
Je pense à COUNT et GROUP BY
Tu penses bien !

Pour t'aider, va faire un tour chez SQLPro.
__________________
Philippe Leménager. Ingénieur d'étude à l'École Nationale de Formation Agronomique.
Mon blog sur la conception des BDD, le langage SQL, le PHP avec Zend Framework...
« Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
À la maison comme au bureau, j'utilise Mandriva Linux ou Mageïa ! Soutenons l'industrie logicielle française !
Linuxiens, comptez-vous !
CinePhil est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/10/2011, 17h49   #3
Invité de passage
 
Inscription : septembre 2006
Messages : 13
Détails du profil
Informations forums :
Inscription : septembre 2006
Messages : 13
Points : 2
Points : 2
Par défaut re

Merci, merci ...
mais je suis un peu perdu sur l'endroit ou placer COUNT et GROUP BY ??

Merci +++

Citation:
Envoyé par CinePhil Voir le message
Tu penses bien !

Pour t'aider, va faire un tour chez SQLPro.
nicodespiennes est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/10/2011, 18h59   #4
Membre actif
 
Homme
Inscription : avril 2011
Messages : 426
Détails du profil
Informations personnelles :
Sexe : Homme

Informations forums :
Inscription : avril 2011
Messages : 426
Points : 171
Points : 171
Un truc du genre

Code :
1
2
3
4
5
6
 
SELECT COUNT(*) AS total
FROM participants
INNER JOIN inscriptions ON inscriptions.num_participant = participants.num_participant
INNER JOIN activites ON activites.num_activite = inscriptions.num_activite
GROUP BY participants.nom
heretik25 est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 05h26.


 
 
 
 
Partenaires

Hébergement Web