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
但显示的结果为

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

你需要用到行转列的sql

https://blog.csdn.net/qq_37949192/article/details/110389113

把表结构贴出来

成绩表SCORE

课程表COURSE

学生表STUDENT

希望可以按照这样显示:

使用行转列的方法达到了结果

您好,我是有问必答小助手,您的问题已经有小伙伴解答了,您看下是否解决,可以追评进行沟通哦~

如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~

ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632

非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!

速戳参与调研>>>https://t.csdnimg.cn/Kf0y