目录
由于MySQL 5不支持窗口函数,因此不能使用PARTITION()、ROW_NUMBER()
🌰:获取每个班级中最新注册的学号人员信息
也就是从 user_info 学生表中获取每个 class_id 班级的最新一条记录
1、MySQL 5版本的写法
🔴写法1:
SELECT u.user_id, u.class_id, u.user_name, u.time
FROM (
SELECT class_id, MAX(time) AS max_time
FROM user_info
GROUP BY class_id
) AS latest
JOIN user_info u ON u.class_id = latest.class_id AND u.time = latest.max_time;
释意:
1、子查询:
- 子查询从 user_info 表中选择 class_id 和每个班级的最大 time 值。
- 使用 GROUP BY class_id 对数据按班级分组。
- 使用 MAX(time) 函数计算每个班级的最大时间值。
2、外层查询:
- 外层查询使用 JOIN 操作连接子查询结果和 user_info 表。