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

2023-10-09 22:15

本文主要是介绍【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.员工奖金

image-20230804145855950

🔑题解

左连接+判空

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

image-20230804150747206

🔑题解

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

image-20230804154519693

🔑题解

  • 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 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.确认率

image-20230804160351893

🔑题解

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

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.有趣的电影

image-20230804161644358

🔑题解

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

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

这篇关于【LeetCode高频SQL50题-基础版】打卡第2天:第11-15题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/175930

相关文章

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

哈希leetcode-1

目录 1前言 2.例题  2.1两数之和 2.2判断是否互为字符重排 2.3存在重复元素1 2.4存在重复元素2 2.5字母异位词分组 1前言 哈希表主要是适合于快速查找某个元素(O(1)) 当我们要频繁的查找某个元素,第一哈希表O(1),第二,二分O(log n) 一般可以分为语言自带的容器哈希和用数组模拟的简易哈希。 最简单的比如数组模拟字符存储,只要开26个c

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

AI基础 L9 Local Search II 局部搜索

Local Beam search 对于当前的所有k个状态,生成它们的所有可能后继状态。 检查生成的后继状态中是否有任何状态是解决方案。 如果所有后继状态都不是解决方案,则从所有后继状态中选择k个最佳状态。 当达到预设的迭代次数或满足某个终止条件时,算法停止。 — Choose k successors randomly, biased towards good ones — Close

leetcode-24Swap Nodes in Pairs

带头结点。 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode(int x) { val = x; }* }*/public class Solution {public ListNode swapPairs(L

leetcode-23Merge k Sorted Lists

带头结点。 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode(int x) { val = x; }* }*/public class Solution {public ListNode mergeKLists

C++ | Leetcode C++题解之第393题UTF-8编码验证

题目: 题解: class Solution {public:static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num &