【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

相关文章

PowerShell中15个提升运维效率关键命令实战指南

《PowerShell中15个提升运维效率关键命令实战指南》作为网络安全专业人员的必备技能,PowerShell在系统管理、日志分析、威胁检测和自动化响应方面展现出强大能力,下面我们就来看看15个提升... 目录一、PowerShell在网络安全中的战略价值二、网络安全关键场景命令实战1. 系统安全基线核查

从基础到进阶详解Pandas时间数据处理指南

《从基础到进阶详解Pandas时间数据处理指南》Pandas构建了完整的时间数据处理生态,核心由四个基础类构成,Timestamp,DatetimeIndex,Period和Timedelta,下面我... 目录1. 时间数据类型与基础操作1.1 核心时间对象体系1.2 时间数据生成技巧2. 时间索引与数据

安装centos8设置基础软件仓库时出错的解决方案

《安装centos8设置基础软件仓库时出错的解决方案》:本文主要介绍安装centos8设置基础软件仓库时出错的解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录安装Centos8设置基础软件仓库时出错版本 8版本 8.2.200android4版本 javas

Linux基础命令@grep、wc、管道符的使用详解

《Linux基础命令@grep、wc、管道符的使用详解》:本文主要介绍Linux基础命令@grep、wc、管道符的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录grep概念语法作用演示一演示二演示三,带选项 -nwc概念语法作用wc,不带选项-c,统计字节数-

python操作redis基础

《python操作redis基础》Redis(RemoteDictionaryServer)是一个开源的、基于内存的键值对(Key-Value)存储系统,它通常用作数据库、缓存和消息代理,这篇文章... 目录1. Redis 简介2. 前提条件3. 安装 python Redis 客户端库4. 连接到 Re

SpringBoot基础框架详解

《SpringBoot基础框架详解》SpringBoot开发目的是为了简化Spring应用的创建、运行、调试和部署等,使用SpringBoot可以不用或者只需要很少的Spring配置就可以让企业项目快... 目录SpringBoot基础 – 框架介绍1.SpringBoot介绍1.1 概述1.2 核心功能2

Spring Boot集成SLF4j从基础到高级实践(最新推荐)

《SpringBoot集成SLF4j从基础到高级实践(最新推荐)》SLF4j(SimpleLoggingFacadeforJava)是一个日志门面(Facade),不是具体的日志实现,这篇文章主要介... 目录一、日志框架概述与SLF4j简介1.1 为什么需要日志框架1.2 主流日志框架对比1.3 SLF4

Spring Boot集成Logback终极指南之从基础到高级配置实战指南

《SpringBoot集成Logback终极指南之从基础到高级配置实战指南》Logback是一个可靠、通用且快速的Java日志框架,作为Log4j的继承者,由Log4j创始人设计,:本文主要介绍... 目录一、Logback简介与Spring Boot集成基础1.1 Logback是什么?1.2 Sprin

MySQL复合查询从基础到多表关联与高级技巧全解析

《MySQL复合查询从基础到多表关联与高级技巧全解析》本文主要讲解了在MySQL中的复合查询,下面是关于本文章所需要数据的建表语句,感兴趣的朋友跟随小编一起看看吧... 目录前言:1.基本查询回顾:1.1.查询工资高于500或岗位为MANAGER的雇员,同时还要满足他们的姓名首字母为大写的J1.2.按照部门

Android Mainline基础简介

《AndroidMainline基础简介》AndroidMainline是通过模块化更新Android核心组件的框架,可能提高安全性,本文给大家介绍AndroidMainline基础简介,感兴趣的朋... 目录关键要点什么是 android Mainline?Android Mainline 的工作原理关键