SQL面试精华:去重、比赛组合与科目对比
需积分: 9 99 浏览量
更新于2024-07-20
收藏 58KB DOC 举报
在SQL面试中,面试官常常会提出一些挑战性的问题来测试求职者的技能和理解。以下是一些经典SQL面试题及其解答,展示了在实际工作中可能会遇到的场景和问题。
1. **多条件筛选学生姓名与成绩筛选**
- 题目要求找出每门课成绩都大于80分的学生姓名。这个问题需要使用子查询来排除成绩不达标的学员。答案是:
```
SELECT DISTINCT name FROM table WHERE name NOT IN (SELECT DISTINCT name FROM table WHERE fenshu <= 80);
```
这个查询首先找出所有成绩低于或等于80分的学生名字,然后在主表中选择没有出现在这些名单中的名字,即所有成绩高于80分的学生。
2. **删除重复记录**
- 删除除自动编号外其他字段完全相同的冗余记录,可以使用`GROUP BY`和`MIN()`函数:
```
DELETE FROM tablename WHERE 自动编号 NOT IN (SELECT MIN(自动编号) FROM tablename GROUP BY 学号, 姓名, 课程编号, 课程名称, 分数);
```
这样能保留每个唯一组合的记录,并删除其余重复项。
3. **部门比赛组合**
- 在部门表(department)中列出所有可能的比赛组合,可以考虑所有球对之间的两两组合,但题目没有给出部门表的实际结构,所以无法提供具体的SQL语句。但基本思路是使用交叉连接(cross join)或笛卡尔积(cartesian product)来生成所有可能的组合。
4. **比较TestDB表中的科目发生额**
- 要找出TestDB表中每月发生额都高于101科目相应月份发生额的科目,可以这样写:
```
SELECT a.*
FROM TestDB a
JOIN (
SELECT Occmonth, MAX(DebitOccur) AS Debit101cur
FROM TestDB
WHERE AccID = '101'
GROUP BY Occmonth
) b ON a.Occmonth = b.Occmonth AND a.DebitOccur > b.Debit101cur;
```
这个查询首先计算科目101在每个月的最大发生额,然后与TestDB中其他科目的发生额进行比较。
5. **未知表结构的多表操作**
- 最后一个问题未提供具体表结构,但根据提示,可能涉及到多表关联。如果有一个yearm表,要完成某个任务,可能需要知道表的结构才能给出准确的SQL语句。假设yearm表包含年份和月份字段,我们需要进一步的信息才能给出相关查询。
总结这些面试题,SQL面试通常关注查询的复杂度、性能优化、数据处理以及对SQL语法的熟练运用。求职者不仅要掌握基本的SQL语句,还要能够灵活应对实际业务场景中的问题。
2018-10-25 上传
2019-02-02 上传
2022-11-08 上传
2024-03-29 上传
2023-06-08 上传
2023-10-19 上传
2024-04-17 上传
2023-07-13 上传
2024-08-31 上传
凤采鸾章
- 粉丝: 1
- 资源: 24
最新资源
- 黑板风格计算机毕业答辩PPT模板下载
- CodeSandbox实现ListView快速创建指南
- Node.js脚本实现WXR文件到Postgres数据库帖子导入
- 清新简约创意三角毕业论文答辩PPT模板
- DISCORD-JS-CRUD:提升 Discord 机器人开发体验
- Node.js v4.3.2版本Linux ARM64平台运行时环境发布
- SQLight:C++11编写的轻量级MySQL客户端
- 计算机专业毕业论文答辩PPT模板
- Wireshark网络抓包工具的使用与数据包解析
- Wild Match Map: JavaScript中实现通配符映射与事件绑定
- 毕业答辩利器:蝶恋花毕业设计PPT模板
- Node.js深度解析:高性能Web服务器与实时应用构建
- 掌握深度图技术:游戏开发中的绚丽应用案例
- Dart语言的HTTP扩展包功能详解
- MoonMaker: 投资组合加固神器,助力$GME投资者登月
- 计算机毕业设计答辩PPT模板下载