【LeetCode高频SQL50题-基础版】打卡第2天:第11-15题

文章目录

  • 【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.员工奖金

【LeetCode高频SQL50题-基础版】打卡第2天:第11-15题_第1张图片

题解

左连接+判空

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.学生们参加各科测试的次数

【LeetCode高频SQL50题-基础版】打卡第2天:第11-15题_第2张图片

题解

通过使用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名直接下属的经理

【LeetCode高频SQL50题-基础版】打卡第2天:第11-15题_第3张图片

题解

  • join+子查询

    首先,我们需要查询出至少有5名下属的员工,这里需要使用 group by 对表中所有的managerId进行一个分组,同时利用 havingcount函数对分组的managerId进行一个统计,这里选择使用having是因为having是分组后的操作,如果直接使用count是不行的,这里必须是分组之后的调用count函数

    select managerId
    from employee
    group by managerId
    having count(managerId >= 5);
    

    然后再利用 join 取交集,这里选择使用 join 不使用 left join是由于结果没有值不能使用 null

    select name
    from employee e1 join(
        select managerId from employee
        group by managerId
        having count(managerId) >= 5) e2
    on e1.id = e2.managerId;
    

    如果使用 left join,首先要交换一下顺序,但是有一个示例数据不能通过,因为 没有匹配值的时候不能取 null,这也是 left join和 join 的区别,一个没有匹配值时直接使用null填充,一个直接不填充

    select name
    from (
        select managerId from employee
        group by managerId
        having count(managerId) >= 5) e2 left join employee e1  
    on e1.id = e2.managerId;
    
  • in+子查询

    select name
    from employee
    where id in (
        select managerId from employee
        group by managerId
        having count(managerId) >= 5);
    

确认率

题目

题目来源:1934.确认率

【LeetCode高频SQL50题-基础版】打卡第2天:第11-15题_第4张图片

题解

主要考察对ROUNDIFNULLAVG这三个知识点的使用

ROUNT(number,n):将number保留n位小数

IFNULL(exp, n):如果 exp 为 null,就取值为 n

AVG(col):计算某个字段的平均值

SELECT
    s.user_id,
    ROUND(IFNULL(AVG(c.action='confirmed'), 0), 2) AS confirmation_rate
FROM
    Signups AS s
LEFT JOIN
    Confirmations AS c
ON
    s.user_id = c.user_id
GROUP BY
    s.user_id;

有趣的电影

题目

题目来源:620.有趣的电影

【LeetCode高频SQL50题-基础版】打卡第2天:第11-15题_第5张图片

题解

这个考察的知识点是mod,相较于上一题感觉难度降低了好多好多

select id,
       movie,
       description,
       rating
from cinema
where description != 'boring' and mod(id, 2) = 1 
order by rating desc;

你可能感兴趣的:(#,leetcode,sql)