我的代码是这样的:
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