У меня есть две таблицы:SQL - наличие VS где
1. Lecturers (LectID, Fname, Lname, degree).
2. Lecturers_Specialization (LectID, Expertise).
Я хочу найти лектора с большей специализации. Когда я пытаюсь это, он не работает:
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);
Но когда я пытаюсь это, она работает:
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);
В чем причина? Благодарю.
Можете ли вы уточнить, какую версию SQL вы используете (MySQL, MS SQL, PostgreSQL, Oracle и т. Д.). Кроме того, когда вы говорите «не работает», вы имеете в виду, что результаты не так, как вы ожидаете, или что существует ошибка компиляции/разбора? – jklemmack
Почему вы используете ALL вместо MAX ?. Есть ли преимущества? – skan