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

SQL - HAVING 与 WHERE

azam45 1月前

35 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)
  • @RoboRobok 我使用聚合来向那些之前没有接触过该概念的人初步解释 having 的含义,因为该功能的动机很容易看出来(在将所有内容相加之前,您无法按总数进行筛选)。一旦他们明白了,我就会推广到前后部分。但我同意你的观点,用聚合来解释 having 就像用阶乘来解释递归一样:如果你就此止步,你就毁了学生的概念。

返回
作者最近主题: