Requete sql
miniJulie
-
miniJulie -
miniJulie -
Bonjour, A tous
j'ai un exercice très long et j'ai presque tout trouver sauf une derniere requete...
si vous pouviez m'aider :
Trouver les noms et numéros de carte des inscrits qui participent à (au moins) un cours auquel participe Bonnard
schéma :
COURS(NomCours,Enseignant,Niveau)
INSCRIT(Nocarte,Nom,Age,Sexe)
PLANNING(NomCours,Jour,Lieu,Heure)
PATICIPATION(Nocarte,NomCours)
merci d'avance pour votre aide...cette question m'aura fait transpiré
j'ai un exercice très long et j'ai presque tout trouver sauf une derniere requete...
si vous pouviez m'aider :
Trouver les noms et numéros de carte des inscrits qui participent à (au moins) un cours auquel participe Bonnard
schéma :
COURS(NomCours,Enseignant,Niveau)
INSCRIT(Nocarte,Nom,Age,Sexe)
PLANNING(NomCours,Jour,Lieu,Heure)
PATICIPATION(Nocarte,NomCours)
merci d'avance pour votre aide...cette question m'aura fait transpiré
A voir également:
- Requete sql
- Logiciel sql - Télécharger - Bases de données
- Sql (+) - Forum Programmation
- Erreur lors de l'envoi de la requête facebook - Forum Facebook
- Requête sql pour afficher uniquement les fleurs dont le prix est strictement inférieur à 10 euros - Forum calculatrices
- Erreur de requete facebook - Forum Facebook
37 réponses
Il me semble que quand on utilises un Having on es censé utiliser un group by donc fais un truc comme ca :
GROUP BY NoCarte ASC HAVING (((COUNT(I.NoCarte)> 1)));
SELECT I.NoCarte, Nom, COUNT(I.NoCarte)
FROM COURS C, INSCRIT I, PARTICIPATION P
WHERE C.NomCours = P.NomCours
AND I.NoCarte = P.NoCarte
AND Nom ='Bonnard'
GROUP BY I.NoCarte, Nom
HAVING (((SUM(I.NoCarte)> 1)));
FROM COURS C, INSCRIT I, PARTICIPATION P
WHERE C.NomCours = P.NomCours
AND I.NoCarte = P.NoCarte
AND Nom ='Bonnard'
GROUP BY I.NoCarte, Nom
HAVING (((SUM(I.NoCarte)> 1)));
non non lol
j'espere que je vous embête pas trop...faut peut-être une sous-requête non ? car jai fait ça question précédente :
select Nom,Age
from INSCRIT
Where Age>( select Age
from Inscrit
where Nom='Bonnard')
j'espere que je vous embête pas trop...faut peut-être une sous-requête non ? car jai fait ça question précédente :
select Nom,Age
from INSCRIT
Where Age>( select Age
from Inscrit
where Nom='Bonnard')
Non pas besoin de sous requête, quelle est la derniere requête que tu as testée ?
As tu essayé avec le group by ?
As tu essayé avec le group by ?
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
La derniere requete est avec le GROUP BY...et ça ne marche pas non plus..apparement le pb vient du SUM
SELECT I.NoCarte, Nom, COUNT(I.NoCarte)
FROM COURS C, INSCRIT I, PARTICIPATION P
WHERE C.NomCours = P.NomCours
AND I.NoCarte = P.NoCarte
AND Nom ='Bonnard'
GROUP BY I.NoCarte, Nom
HAVING (((COUNT(I.NoCarte)> 1)))
Là je n'ai aucun problème mais jpense pas que ce soit la réponse...car ça ne me trouve aucune personne...
FROM COURS C, INSCRIT I, PARTICIPATION P
WHERE C.NomCours = P.NomCours
AND I.NoCarte = P.NoCarte
AND Nom ='Bonnard'
GROUP BY I.NoCarte, Nom
HAVING (((COUNT(I.NoCarte)> 1)))
Là je n'ai aucun problème mais jpense pas que ce soit la réponse...car ça ne me trouve aucune personne...
tu es sur d'avoir au moins un résultat correspondant à ta requête ???
Et essayes de virer toutes ces parenthèses dans le having
Et essayes de virer toutes ces parenthèses dans le having
Si elle est bonne la requete! Maintenant a toi d'alimenter ta BDD pour que cette requete fonctionne avec plusieurs exemple....
Vous savez quoi j'ai peut-etre mal regardé...jpense que c'est bon en fait...
maintenant si vous pouviez me répondre à une deuxieme petite question...je dois faire cette question avec le JOIN et l'agregation...
Trouver les inscrits au cours de NATATION I et de NATATION II
j'ai
select distinct Inscrit.*,Cours.NomCours
from INSCRIT,PARTICIPATION,COURS
where Inscrit.Nocarte=Participation.Nocarte
and Participation.NomCours=Cours.NomCours
and Cours.NomCours='NatationI'or Cours.NomCours='NatationII'
et
select Inscrit.*,Cours.NomCours
from (INSCRIT join PARTICIPATION on Inscrit.Nocarte=Participation.Nocarte)
join Cours on Participation.NomCours=Cours.NomCours
where Cours.NomCours='NatationI'or Cours.NomCours='NatationII'
les deux marchent mais ne donnent pas le même résultat pk ?
maintenant si vous pouviez me répondre à une deuxieme petite question...je dois faire cette question avec le JOIN et l'agregation...
Trouver les inscrits au cours de NATATION I et de NATATION II
j'ai
select distinct Inscrit.*,Cours.NomCours
from INSCRIT,PARTICIPATION,COURS
where Inscrit.Nocarte=Participation.Nocarte
and Participation.NomCours=Cours.NomCours
and Cours.NomCours='NatationI'or Cours.NomCours='NatationII'
et
select Inscrit.*,Cours.NomCours
from (INSCRIT join PARTICIPATION on Inscrit.Nocarte=Participation.Nocarte)
join Cours on Participation.NomCours=Cours.NomCours
where Cours.NomCours='NatationI'or Cours.NomCours='NatationII'
les deux marchent mais ne donnent pas le même résultat pk ?