J'ai les deux tableaux suivants :
1. Lecturers (LectID, Fname, Lname, degree).
2. Lecturers_Specialization (LectID, Expertise).
Je veux trouver le professeur qui a le plus de spécialisation. Lorsque j'essaie de le faire, cela ne fonctionne pas :
SELECT
L.LectID,
Fname,
Lname
FROM Lecturers L,
Lecturers_Specialization S
WHERE L.LectID = S.LectID
AND COUNT(S.Expertise) >= ALL (SELECT
COUNT(Expertise)
FROM Lecturers_Specialization
GROUP BY LectID);
Mais quand j'essaie ça, ça marche :
SELECT
L.LectID,
Fname,
Lname
FROM Lecturers L,
Lecturers_Specialization S
WHERE L.LectID = S.LectID
GROUP BY L.LectID,
Fname,
Lname
HAVING COUNT(S.Expertise) >= ALL (SELECT
COUNT(Expertise)
FROM Lecturers_Specialization
GROUP BY LectID);
Quelle en est la raison ? Merci.
3 votes
Pouvez-vous préciser quelle version de SQL vous utilisez (MySQL, MS SQL, PostgreSQL, Oracle, etc.). De plus, lorsque vous dites "ne fonctionne pas", voulez-vous dire que les résultats ne sont pas ceux que vous attendez, ou qu'il y a une erreur de compilation/parse ?
3 votes
Pourquoi utilisez-vous ALL au lieu de MAX ?. Y a-t-il un avantage ?