sql面试题

这里写目录标题

1.只保留学生的最新成绩

表student中记录学生的成绩信息, 要求只保留学生的最新一条成绩记录

传统方式:

  1. 根据学生编号进行group by, 找到最新的一条记录(编号、时间)
  2. 根据编号和时间, 查询出记录的完整信息(id为2, 5, 6)
  3. 删除其余记录
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
)

通过联表查询, 解决嵌套

  1. 通过与自身表进行关联, 让同一个人的记录互相进行对比,
  2. 设置条件s1.time > s2.time, 且使用left join, 保证时间早的记录被归档在右侧
  3. 即使只有一条记录, 也会被s1.id != s2.id过滤
  4. 时间最晚的那条记录, 永远不会出现在右侧. 右侧都是对比下来, 时间更早的数据, 我们将它们的id排重
  5. 删除这些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
)
相关推荐
Knight_AL5 小时前
MySQL STORED 生成列(Generated Column)详解:让 SQL 变快的秘密武器
数据库·sql·mysql
Dragon online6 小时前
数据分析师成长之路--从SQL恐惧到数据掌控者的蜕变
数据库·sql
Li.CQ8 小时前
SQL学习笔记
笔记·sql·学习
Navicat中国9 小时前
Navicat 技术指引 | 面向达梦的查询工具
数据库·sql·达梦·navicat·查询
编织幻境的妖10 小时前
SQL执行计划与优化详解
数据库·sql
我命由我1234511 小时前
Android 开发 Room 问题:SQL error or missing database (no such table: User)
java·数据库·sql·java-ee·android studio·android-studio·android runtime
Wokoo712 小时前
乐观锁与悲观锁:死锁分析与解决方案
java·数据库·后端·sql
麦聪聊数据12 小时前
生成测试数据(二):快速创建测试数据,校验前端与 UI 适配性
前端·数据库·sql
金刚猿12 小时前
IntelliJ IDEA 主题、字体、括号、变量、注释、sql 、辅助线、作者信息等颜色、操作修改大全
java·sql·intellij-idea·背景颜色
编织幻境的妖12 小时前
SQL聚合函数功能与用法详解
java·数据库·sql