msyql 分组前几名sql

成绩表 c_score

ids_name(学生姓名)c_name(课程名)score(分数)
sql检索每门课程的前5名学生的姓名和成绩

SELECT a.c_name,a.s_name,a.score FROM c_score a WHERE 5 >( SELECT COUNT(*) FROM c_score b WHERE b.c_name = a.c_name AND b.score > a.score) ORDER BY a.c_name;

sql执行顺序如下
1 从a表里取出一条数据(from c_score a执行),此时a.name 和a.score为一个定值,例如a.c_name='数学' a.score=80 a.s_name='张三'
2 进行子查询, SELECT COUNT(*) FROM c_score b WHERE b.c_name = a.c_name AND b.score < a.score 执行,计算出数学中比80分大的数量
3 WHERE 5 > 执行,如果第二步计算结果小于5,则表示比80分大的人数少于5人,张三至少是第五名,符合检索条件,反之不符合
4 对成绩表全部数据循环执行 1-3步,得出每门课的前五名
5 取符合前四步数据的c_name,s_name,score列
6 对结果按c_name 升序排列

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值