ProgramApeLi 2021-05-06 16:35 采纳率: 100%
浏览 57
已采纳

ORACLE中分别获取三门课程的前三名并一行显示

我的代码是这样的:

SELECT T.CNAME AS 课程名称,
       (SELECT T.SNAME FROM T WHERE T.RO = 1) AS 第1名,
       (SELECT T.SNAME FROM T WHERE T.RO = 2) AS 第2名,
       (SELECT T.SNAME FROM T WHERE T.RO = 3) AS 第3名
  FROM (SELECT C.CNAME, S.SNAME, RO.RO
          FROM (SELECT SID,
                       CID,
                       ROW_NUMBER() OVER(PARTITION BY CID ORDER BY SCORE DESC) AS RO
                  FROM SCORE) RO,
               COURSE C,
               STUDENT S
         WHERE RO.CID = C.CID
           AND S.SID = RO.SID
           AND C.CNAME IN ('企业管理', '马克思思想', '数据库')
         ORDER BY RO.CID) T
但显示的结果为

有什么办法可以做到一行显示课程名称和成绩吗?

  • 写回答

7条回答 默认 最新

  • Mr.Qubb 2021-05-06 16:48
    关注
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(6条)

报告相同问题?