查询各科成绩前三名的记录:(不考虑成绩并列情况)

lcnflylee1 2015-07-30 09:33:33
create table sc(
sno varchar2(10),
cno varchar2(10),
score number(4,2),
constraint pk_sc primary key (sno,cno)
)

insert into sc values ('s001','c001',78.9);
insert into sc values ('s002','c001',80.9);
insert into sc values ('s003','c001',81.9);
insert into sc values ('s004','c001',60.9);
insert into sc values ('s001','c002',82.9);
insert into sc values ('s002','c002',72.9);
insert into sc values ('s003','c002',81.9);
insert into sc values ('s001','c003','59');

代码:
SELECT t1.sno,t1.cno,Score
FROM SC t1
WHERE score IN (SELECT TOP 3 score
FROM SC
WHERE t1.cno= cno)
ORDER BY t1.cno,score desc
我很疑惑WHERE t1.cno= cno这个是什么意思,大神们能不能详细讲解整个代码,最好说一下写这些的思路是怎样的?本人菜鸟。
...全文
3621 4 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
卖水果的net 2015-07-31
  • 打赏
  • 举报
回复
WHERE t1.cno= cno 是为了区分不同的课程 。 但是,建议 LZ 使用分析函数来解这个问题,可以百度一下 row_number , rank() , dense_rank 这三个

select *
  from (select sno,
               cno,
               score,
               row_number() over(partition by cno order by score desc) rn
          from sc)
 where rn <= 3
/
Landa_Tiny_cui 2015-07-31
  • 打赏
  • 举报
回复
你这是Oracle数据库啊, 不过SQL语句还是一样的。 这是个相关子查询,你可以查‘’相关子查询‘’的资料说的很详细 你这个相关子查询语句前面的叫外部查询,where里面的是内部查询。 查询的机制是每一个外部查询都会当做内部查询的条件, 就是你在SC表里查出第一个的CNO=‘c001’,内部查询查出的每一条,会和这条比对(相当于内部查询的where条件是cno='c001'),这时里面查询会返回4条CNO='c001'的集合,在根据top 3 score返回3条成绩最高的,然后这3条成绩最高的当做外部查询里in 后面的条件 返回出CNO=‘c001’中你要的成绩最高的3个人。这是第一个CNO, 然后第二个继续从外部查询出 CNO='c002'传给内部查询,还和刚才一样,返回来CNO='c002'的成绩最高的3个人。 当外部查询的所有CNO都传给内部后,全部结束,查询出你要的集合
zbdzjx 2015-07-31
  • 打赏
  • 举报
回复
楼主的这些语句有两个问题。 1、varchar2是Oracle里面的,但TOP 3却是SQL Server中的。 2、后面的查询语句,WHERE t1.cno= cno后面要加order by score desc,不然查询出来的不是最高的三名了。
火拼阿三 2015-07-31
  • 打赏
  • 举报
回复 1
楼上的2个都说的很对,但是还是建议用row_number() over(partition by cno order by score desc)

27,580

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 应用实例
社区管理员
  • 应用实例社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧