【发布时间】:2012-03-04 10:12:32
【问题描述】:
我有以下两张表:
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 等)。另外,当您说“不起作用”时,您的意思是结果与您预期的不一样,还是存在编译/解析错误?
-
为什么使用 ALL 而不是 MAX?有什么优势吗?
标签: sql where-clause having