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

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
    最佳回答
    评论
    解决 1 无用
    打赏 举报
查看更多回答(6条)

相关推荐 更多相似问题