文章目录
- 【LeetCode高频SQL50题-基础版】打卡第2天:第11-15题
- ⛅前言
- 员工奖金
- 🔒题目
- 🔑题解
- 学生们参加各科测试的次数
- 🔒题目
- 🔑题解
- 至少有5名直接下属的经理
- 🔒题目
- 🔑题解
- 确认率
- 🔒题目
- 🔑题解
- 有趣的电影
- 🔒题目
- 🔑题解
【LeetCode高频SQL50题-基础版】打卡第2天:第11-15题
⛅前言
在这个博客专栏中,我将为大家提供关于 LeetCode 高频 SQL 题目的基础版解析。LeetCode 是一个非常受欢迎的编程练习平台,其中的 SQL 题目涵盖了各种常见的数据库操作和查询任务。对于计算机科班出身的同学来说,SQL 是一个基础而又重要的技能。不仅在面试过程中经常会遇到 SQL 相关的考题,而且在日常的开发工作中,掌握 SQL 的能力也是必备的。
本专栏的目的是帮助读者掌握 LeetCode 上的高频 SQL 题目,并提供对每个题目的解析和解决方案。我们将重点关注那些经常出现在面试中的题目,并提供一个基础版的解法,让读者更好地理解问题的本质和解题思路。无论你是准备找工作还是提升自己的技能,在这个专栏中,你可以学习到很多关于 SQL 的实践经验和技巧,从而更加深入地理解数据库的操作和优化。
我希望通过这个专栏的分享,能够帮助读者在 SQL 的领域里取得更好的成绩和进步。如果你对这个话题感兴趣,那么就跟随我一起,开始我们的 LeetCode 高频 SQL 之旅吧!
- 博客主页💖:知识汲取者的博客
- LeetCode高频SQL100题专栏🚀:LeetCode高频SQL100题_知识汲取者的博客-CSDN博客
- Gitee地址📁:知识汲取者 (aghp) - Gitee.com
- 题目来源📢:高频 SQL 50 题(基础版) - 学习计划 - 力扣(LeetCode)全球极客挚爱的技术成长平台
员工奖金
🔒题目
题目来源:577.员工奖金
🔑题解
左连接
+判空
select e.name, b.bonus
from employee e left join bonus b on e.empId = b.empId
where b.bonus < 1000 or b.bonus is null;
备注:本题新手可能会容易会略 null 值,MySQL中 null 值不参与比较运算,因为 null 是一个不确定的值,MySQL无法确定他是数字还是字符串还是日期,所以不参与比较
学生们参加各科测试的次数
🔒题目
题目来源:1280.学生们参加各科测试的次数
🔑题解
通过使用INNER JOIN
将学生表和科目表连接起来,然后使用LEFT JOIN
将考试表与前面的结果进行关联,即可计算出每个学生在每一门科目上的测试次数。最后,使用GROUP BY
对 学生ID 和 科目名称 进行分组,并按照 学生ID 和 科目名称 进行排序。
SELECT stu.student_id, stu.student_name, sub.subject_name, COUNT(exa.subject_name) AS attended_exams
FROM students stu JOIN subjects sub
LEFT JOIN examinations exa ON exa.student_id = stu.student_id AND exa.subject_name = sub.subject_name
GROUP BY stu.student_id, sub.subject_name
ORDER BY stu.student_id, sub.subject_name;
通过使用 join
将 stu 和 sub 两张表进行内连接,由于 stu 和 sub 没有公共字段,就直接取笛卡尔积,然后将这个得到的笛卡尔积与 exa 表进行左外连接查询,通过 on 条件进行筛选 最终可以得到所有的组合,最后还需要通过 group by 对 student_id 和 subject_name进行一个分组操作,最终再进行一个排序,就得到最终答案了
PS:三表联查,这个SQL写起来还是有定东西的,可能是平常SQL写少了,大部分都是直接使用MyBatisPlus的API进行单表操作
至少有5名直接下属的经理
🔒题目
题目来源:570.至少有5名直接下属的经理
🔑题解
-
join
+子查询
首先,我们需要查询出至少有5名下属的员工,这里需要使用
group by
对表中所有的managerId
进行一个分组,同时利用having
和count
函数对分组的managerId进行一个统计,这里选择使用having
是因为having
是分组后的操作,如果直接使用count是不行的,这里必须是分组之后的调用count函数select managerId from employee group by managerId having count(managerId >= 5);
然后再利用
join
取交集,这里选择使用 join 不使用 left join是由于结果没有值不能使用 nullselect name from employee e1 join(select managerId from employeegroup by managerIdhaving count(managerId) >= 5) e2 on e1.id = e2.managerId;
如果使用
left join
,首先要交换一下顺序,但是有一个示例数据不能通过,因为 没有匹配值的时候不能取 null,这也是 left join和 join 的区别,一个没有匹配值时直接使用null填充,一个直接不填充select name from (select managerId from employeegroup by managerIdhaving count(managerId) >= 5) e2 left join employee e1 on e1.id = e2.managerId;
-
in
+子查询
select name from employee where id in (select managerId from employeegroup by managerIdhaving count(managerId) >= 5);
确认率
🔒题目
题目来源:1934.确认率
🔑题解
主要考察对ROUND
,IFNULL
、AVG
这三个知识点的使用
ROUNT(number,n)
:将number保留n位小数
IFNULL(exp, n)
:如果 exp 为 null,就取值为 n
AVG(col)
:计算某个字段的平均值
SELECTs.user_id,ROUND(IFNULL(AVG(c.action='confirmed'), 0), 2) AS confirmation_rate
FROMSignups AS s
LEFT JOINConfirmations AS c
ONs.user_id = c.user_id
GROUP BYs.user_id;
有趣的电影
🔒题目
题目来源:620.有趣的电影
🔑题解
这个考察的知识点是mod
,相较于上一题感觉难度降低了好多好多
select id,movie,description,rating
from cinema
where description != 'boring' and mod(id, 2) = 1
order by rating desc;