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

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

报告相同问题?

悬赏问题

  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿
  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘