我一直试图将结果操纵到这三个查询中,我不知道我在做什么错误
列出参加少于三个小组的所有学术成员。
列出导致最大群组数量的学术ID
使用此查询(第一部分)
SELECT a.ID , min(a.name) as Name
FROM Academic a , researchGroup r
WHERE count(r.managerID)>3
GROUP BY a.ID;
但它似乎不起作用。
我有这个关系模式
researchGroup(name (P.R Key Composite) , codeD , mainResearchArea , managerID /* forgien key with AcademicStaff(ID) */ , labID (P.R Key Composite) )
AcademicStaff(ID {PR KEY} , name)
任何解决方案?
答案 0 :(得分:1)
以下内容将为您提供学术列表和管理的研究组数量:
SELECT
*
FROM
(
SELECT
ac.ID AS academic_id
,MAX(ac.name) AS academic_name
,COUNT(rg.managerID) AS num_groups_managed
,DENSE_RANK() OVER (ORDER BY COUNT(rg.managerID) DESC) AS academic_rank
FROM
Academic AS ac
INNER JOIN
researchGroup AS rg
ON (rg.managerID = ac.ID)
GROUP BY
ac.ID
) AS subquery
WHERE
--** uncomment the following line for the academics managing above 3 groups
--num_groups_managed >= 3
--** or uncomment the following line for the top-ranked academics (there could be more than 1)
--academic_rank = 1
ORDER BY
academic_rank ASC
,academic_name ASC
取消注释WHERE子句的相关部分将为您提供所需的结果。
顺便说一下,因为我使用过Oracle SQL,所以请原谅任何小的语法错误(特别是,我不记得Oracle是否接受了关键字AS
。表名)。