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语句:
时间: 2024-03-01 21:55:45 浏览: 113
可以使用以下SQL语句计算每年在校人数:
```
SELECT year, SUM(num) * stu_len AS enrollment
FROM admit
GROUP BY year, stu_len
ORDER BY year;
```
这个查询首先按照入学年度和学制对记录进行分组,然后计算每个分组中的所有录取学生人数之和,乘以学制长度,得到每个分组对应的在校人数。最后按照入学年度排序,返回结果集。
根据示例数据,以上SQL语句会返回以下结果:
```
year enrollment
---- ----------
2018 6000
2019 6000
2020 11000
```
其中,2018年的在校人数是2000 * 3 = 6000,2019年的在校人数也是6000,2020年的在校人数是1000 * 4 + 2000 * 3 = 11000。
阅读全文
相关推荐
![-](https://img-home.csdnimg.cn/images/20241231044833.png)
![-](https://img-home.csdnimg.cn/images/20241231044833.png)
![-](https://img-home.csdnimg.cn/images/20241231044833.png)
![docx](https://img-home.csdnimg.cn/images/20241231044901.png)
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![doc](https://img-home.csdnimg.cn/images/20241231044833.png)
![rar](https://img-home.csdnimg.cn/images/20241231044955.png)
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![pdf](https://img-home.csdnimg.cn/images/20241231044930.png)
![doc](https://img-home.csdnimg.cn/images/20241231044833.png)
![doc](https://img-home.csdnimg.cn/images/20241231044833.png)
![doc](https://img-home.csdnimg.cn/images/20241231044833.png)
![docx](https://img-home.csdnimg.cn/images/20241231044901.png)
![docx](https://img-home.csdnimg.cn/images/20241231044901.png)
![application/x-rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![pdf](https://img-home.csdnimg.cn/images/20241231044930.png)
![rar](https://img-home.csdnimg.cn/images/20241231044955.png)