mysql如何实现每个专业分数段统计人数

来源:APP编程网作者:深圳网站建设头衔:草根站长
导读:本期聚焦于小伙伴创作的《mysql如何实现每个专业分数段统计人数》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《mysql如何实现每个专业分数段统计人数》有用,将其分享出去将是对创作者最好的鼓励。

在成绩管理相关的业务场景中,经常需要按专业统计不同分数段的学生人数,比如统计每个专业中0-59分、60-79分、80-89分、90-100分各区间的人数,这类需求可以通过mysql的条件判断和分组统计功能实现。

基础表结构设计

首先我们需要有一个存储学生成绩信息的基础表,假设表名为student_score,包含学生ID、专业名称、考试成绩三个核心字段,建表语句如下:

CREATE TABLE student_score (
    id INT PRIMARY KEY AUTO_INCREMENT,
    student_name VARCHAR(50) NOT NULL,
    major VARCHAR(50) NOT NULL,
    score DECIMAL(5,2) NOT NULL
);

我们可以插入一些测试数据方便后续验证统计逻辑:

INSERT INTO student_score (student_name, major, score) VALUES
('张三', '计算机科学与技术', 85.5),
('李四', '计算机科学与技术', 72.0),
('王五', '计算机科学与技术', 56.0),
('赵六', '软件工程', 92.0),
('钱七', '软件工程', 88.0),
('孙八', '软件工程', 63.0),
('周九', '软件工程', 45.0),
('吴十', '电子信息工程', 79.0),
('郑十一', '电子信息工程', 91.5),
('王十二', '电子信息工程', 68.0);

核心实现思路

要实现每个专业的分数段人数统计,核心分为三步:

  • 第一步:定义分数段的划分规则,明确每个分数区间对应的条件
  • 第二步:使用CASE WHEN语句根据成绩匹配对应的分数段
  • 第三步:按专业分组,同时统计每个分数段的人数

完整统计SQL编写

假设我们划分4个分数段:不及格(0-59分)、及格(60-79分)、良好(80-89分)、优秀(90-100分),对应的统计SQL如下:

SELECT 
    major AS 专业名称,
    COUNT(CASE WHEN score >= 0 AND score < 60 THEN 1 END) AS 不及格人数,
    COUNT(CASE WHEN score >= 60 AND score < 80 THEN 1 END) AS 及格人数,
    COUNT(CASE WHEN score >= 80 AND score < 90 THEN 1 END) AS 良好人数,
    COUNT(CASE WHEN score >= 90 AND score <= 100 THEN 1 END) AS 优秀人数,
    COUNT(*) AS 专业总人数
FROM student_score
GROUP BY major
ORDER BY major;

语句逻辑解析

上述SQL的核心逻辑说明:

  • CASE WHEN语句会根据score的值判断当前学生属于哪个分数段,匹配到对应条件时返回1,否则返回NULL
  • COUNT函数统计非NULL值的数量,因此每个分数段的COUNT就会得到对应区间的人数
  • GROUP BY major会按专业分组,保证统计结果是以专业为维度的
  • 最后可以额外加一个专业总人数的统计,方便核对数据准确性

执行结果示例

执行上述SQL后,会得到类似如下的统计结果:

专业名称不及格人数及格人数良好人数优秀人数专业总人数
计算机科学与技术11103
软件工程11114
电子信息工程01013

注意事项

在实际使用过程中需要注意以下几点:

  • 分数段的边界值要和CASE WHEN中的条件完全匹配,避免出现成绩漏统计或者重复统计的情况,比如60分属于及格段就不要同时出现在不及格段的条件中
  • 如果成绩存在NULL值,需要提前处理,比如在CASE WHEN中增加WHEN score IS NULL THEN NULL的逻辑,避免NULL值被错误统计
  • 如果专业名称存在重复或者大小写不一致的情况,建议先对major字段做去重或者统一格式的处理,保证分组结果的准确性

扩展场景

如果需要动态调整分数段的划分规则,比如不同专业采用不同的分数段标准,可以在CASE WHEN中增加专业判断条件,示例如下:

SELECT 
    major AS 专业名称,
    COUNT(CASE WHEN 
        (major = '计算机科学与技术' AND score >= 0 AND score < 60) OR 
        (major != '计算机科学与技术' AND score >= 0 AND score < 55) 
    THEN 1 END) AS 不及格人数
FROM student_score
GROUP BY major;

这种写法可以根据不同专业设置不同的不及格分数线,满足更复杂的业务统计需求。

mysql分数段统计专业分组CASE_WHENCOUNT函数修改时间:2026-06-19 01:15:48

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。