php ,mysql 谁能帮我分段统计各分数段的人数并显示出来 grade成绩表,sgrade学生成绩,cid课程号

php ,mysql 谁能帮我分段统计各分数段的人数并显示出来 grade成绩表,sgrade学生成绩,cid课程号,第1张

select count(*) from grade where cid = $cid group by sgrade

你分数段是什么意思,是指60-80多少人,80-100多少人? 还是 61分 2人 ,62分0人 , 63分3人.....这样。

select

sum(case when sgrade <100 and sgrade >89 then 1 else 0 end) as 'scroeA',

sum(case when sgrade <90 and sgrade >79 then 1 else 0 end) as 'scroeB',

sum(case when sgrade <80 and sgrade >69 then 1 else 0 end) as 'scroeC',

sum(case when sgrade <70 and sgrade >59 then 1 else 0 end) as 'scroeD'

from grade where cid = $cid group by sgrade

要求查找到学校不同年级中每个年级的最高分人员信息,并列第一的学生信息都要查询出来

首先准备数据

分析:可以使用group by 对班级进行分组,再使用max函数找出每个年级的最高分数,所以可以这样写

执行上面的语句可以得到如下结果

可以看出这样已经查询出每个年级对应的最高分,那根据这2个条件,再去表里查询对应年级和分数的学生信息即可

这样执行出来的结果就可以找到每个年级最高分的学生信息,同时并列第一的学生也可以查询到,结果如下

注意:查询列中的字段如果不是group by的字段,那么需要对该字段使用聚合函数,所以这里使用max()找出最大值,而student字段是没法使用的,否则查询出来的就是多个,所以需要使用子查询


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/6130128.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-15
下一篇 2023-03-15

发表评论

登录后才能评论

评论列表(0条)

保存