示例计算出每年在校人数,写出SQL语句
时间: 2023-09-20 13:08:19 浏览: 349
假设有一个名为"students"的表,包含以下列:id(学生ID),name(学生姓名),enrollment_date(入学日期),graduation_date(毕业日期)。
为了计算每年在校人数,可以使用以下SQL语句:
```
SELECT YEAR(enrollment_date) AS year, COUNT(*) AS total_students
FROM students
WHERE enrollment_date IS NOT NULL AND graduation_date IS NULL
GROUP BY YEAR(enrollment_date);
```
该语句首先排除毕业日期不为空的学生,然后按入学年份分组,并计算每年在校学生的总数。该语句返回一个结果集,其中包含每年在校人数。
相关问题
year表示学生入学年度 num表示对应年度录取学生人数 stu_len表示录取学生的学制 说明:例如录取年度2018学制3,表示该批学生在校年份为2018~2019、2019~2020、2020~2021 以下是示例数据: id year num stu_len 1 2018 2000 3 2 2019 2000 3 3 2020 1000 4 4 2020 2000 3 根据以上示例计算出每年在校人数,写出SQL语句:
你可以使用以下SQL语句来计算每年在校人数:
```sql
SELECT year, SUM(num) AS total_students
FROM your_table_name
GROUP BY year
```
请将`your_table_name`替换为你的表名。这条SQL语句将根据年份对人数进行求和,并返回每年的在校人数总数。
1.有一个录取学生人数表,记录的是每年录取学生人数和入学学生的学制 以下是表结构: CREATE TABLE `admit` ( `id` int(11) NOT NULL AUTO_INCREMENT, `year` int(255) DEFAULT NULL COMMENT '入学年度', `num` int(255) DEFAULT NULL COMMENT '录取学生人数', `stu_len` varchar(255) DEFAULT NULL COMMENT '学生学制', PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8mb4 COMMENT='录取人数'; year表示学生入学年度 num表示对应年度录取学生人数 stu_len表示录取学生的学制 说明:例如录取年度2018学制3,表示该批学生在校年份为2018~2019、2019~2020、2020~2021 以下是示例数据: id year num stu_len 1 2018 2000 3 2 2019 2000 3 3 2020 1000 4 4 2020 2000 3 根据以上示例计算出每年在校人数,写出SQL语句
可以使用子查询和聚合函数来计算每年在校人数:
```sql
SELECT year, SUM(num * (CASE stu_len WHEN 3 THEN 3 WHEN 4 THEN 4 END)) AS total_students
FROM admit
GROUP BY year;
```
解释:首先根据学制计算每个学生在校年份的总和,然后再将同一年的学生人数相加得到每年在校人数的总和。最终按照年份分组,使用SUM函数计算每组的总和。
阅读全文
相关推荐






