这里写目录标题
1.只保留学生的最新成绩
表student中记录学生的成绩信息, 要求只保留学生的最新一条成绩记录
传统方式:
- 根据学生编号进行group by, 找到最新的一条记录(编号、时间)
- 根据编号和时间, 查询出记录的完整信息(id为2, 5, 6)
- 删除其余记录
sql
delete from student where id not in (
select id from student s1 inner join
(select `name`, max(time) as time from student group by `name`) s2
on s1.name = s2.name and s1.time = s2.time
)
通过联表查询, 解决嵌套
- 通过与自身表进行关联, 让同一个人的记录互相进行对比,
- 设置条件s1.time > s2.time, 且使用left join, 保证时间早的记录被归档在右侧
- 即使只有一条记录, 也会被s1.id != s2.id过滤
- 时间最晚的那条记录, 永远不会出现在右侧. 右侧都是对比下来, 时间更早的数据, 我们将它们的id排重
- 删除这些id
sql
delete from student where id in (
select DISTINCT s2.id
from student s1 left join student s2
on s1.`no` = s2.`no` and s1.id != s2.id
where s1.time > s2.time
)