8wDlpd.png
8wDFp9.png
8wDEOx.png
8wDMfH.png
8wDKte.png

SQL - HAVING 与 WHERE

azam45 1月前

37 0

我有以下两个表:1. 讲师 (LectID、Fname、Lname、学位)。2. 讲师专业化 (LectID、专业知识)。我想找到专业化程度最高的讲师。当我尝试...

我有以下两个表:

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); 

是什么原因?谢谢。

帖子版权声明 1、本帖标题:SQL - HAVING 与 WHERE
    本站网址:http://xjnalaquan.com/
2、本网站的资源部分来源于网络,如有侵权,请联系站长进行删除处理。
3、会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。
4、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报
5、站长邮箱:yeweds@126.com 除非注明,本帖由azam45在本站《sqlite》版块原创发布, 转载请注明出处!
最新回复 (0)
  • 您关于优化的观点是将 [country] 移至 WHERE,因为这样以后使用 GROUP BY 时数据集会更小。当然,这只是一个示例,用于说明可能的用途。我们可以改为 HAVING sum(total) > 1000,这将是包含 WHERE 和 HAVING 的完全有效的案例。

返回
作者最近主题: