对学生选课数据库,编写存储过程,统计某课程(如离散数学)的成绩 分布情况,即按照各分数段统计人数
时间: 2023-07-07 15:13:27 浏览: 255
好的,针对您的问题,我可以为您提供如下的存储过程示例:
```
CREATE PROCEDURE CountCourseGradeDistribution (IN courseName VARCHAR(255))
BEGIN
SELECT CONCAT('分数段:[', floor(lower_bound), '-', ceil(upper_bound), '),人数:', COUNT(*))
FROM (
SELECT
CASE
WHEN grade < 60 THEN 0
WHEN grade >= 60 AND grade < 70 THEN 60
WHEN grade >= 70 AND grade < 80 THEN 70
WHEN grade >= 80 AND grade < 90 THEN 80
ELSE 90
END AS lower_bound,
CASE
WHEN grade < 60 THEN 60
WHEN grade >= 60 AND grade < 70 THEN 70
WHEN grade >= 70 AND grade < 80 THEN 80
WHEN grade >= 80 AND grade < 90 THEN 90
ELSE 100
END AS upper_bound
FROM
student_course
WHERE
course_name = courseName
) AS grade_ranges
GROUP BY
lower_bound, upper_bound;
END;
```
这个存储过程接受一个参数 courseName,表示要统计哪门课程的成绩分布情况。它会查询 student_course 表,将每个学生在这门课程上的成绩划分到不同的分数段中,并按照分数段统计人数。
在这个存储过程中,我们使用了一个子查询来计算每个成绩应该属于哪个分数段。子查询中使用了 CASE WHEN 语句,根据不同的成绩范围将成绩分配到不同的分数段中。然后,我们将分数段按照下限和上限分别取整,并将它们作为查询结果的两个字段。
最后,我们将这些结果按照分数段进行分组,并使用 CONCAT 函数将分数段和人数拼接成字符串,作为最终的查询结果返回。
您可以根据需要修改这个存储过程,比如修改分数段的范围,或者添加更多的统计项。
阅读全文