使用带有比较的子查询 - Oracle

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用带有比较的子查询 - Oracle相关的知识,希望对你有一定的参考价值。

我一直试图将结果操纵到这三个查询中,我不知道我在做什么是错的

列出参加不到三组的所有学术成员。

列出导致最大组数的学术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)

任何解决方案

答案

以下将为您提供学术列表和管理的研究组数量:

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

以上是关于使用带有比较的子查询 - Oracle的主要内容,如果未能解决你的问题,请参考以下文章

中继fetchQuery:如何在没有片段结构的情况下获取查询结果

Oracle - IF 子句中的子查询 [重复]

在带有 ORDER BY 的子选择中使用 JSON_ARRAYAGG 会出错

数据库系统原理作业七数据查询中的嵌套查询

使用 Oracle SQL 的子查询

使用带有更新 SQL 的子查询