当前位置: 首页 > news >正文

MySQL高阶练习题1- 寻找面试候选人

目录

题目

准备数据

分析数据

实现代码

总结


题目

返回 所有面试候选人 的姓名 name 和邮件 mail 。当用户满足以下两个要求中的 任意一条 ,其成为 面试候选人 :

  • 该用户在 连续三场及更多 比赛中赢得 任意 奖牌。
  • 该用户在 三场及更多不同的 比赛中赢得 金牌(这些比赛可以不是连续的)

准备数据

## 创建库
create database db;
use db;## 创建Contests表
Create table If Not Exists Contests (contest_id int, gold_medal int, silver_medal int, bronze_medal int);## 创建Users表
Create table If Not Exists Users (user_id int, mail varchar(50), name varchar(30));## 向表中插入数据
Truncate table Contests;
insert into Contests (contest_id, gold_medal, silver_medal, bronze_medal) values ('190', '1', '5', '2');
insert into Contests (contest_id, gold_medal, silver_medal, bronze_medal) values ('191', '2', '3', '5');
insert into Contests (contest_id, gold_medal, silver_medal, bronze_medal) values ('192', '5', '2', '3');
insert into Contests (contest_id, gold_medal, silver_medal, bronze_medal) values ('193', '1', '3', '5');
insert into Contests (contest_id, gold_medal, silver_medal, bronze_medal) values ('194', '4', '5', '2');
insert into Contests (contest_id, gold_medal, silver_medal, bronze_medal) values ('195', '4', '2', '1');
insert into Contests (contest_id, gold_medal, silver_medal, bronze_medal) values ('196', '1', '5', '2');
Truncate table Users;
insert into Users (user_id, mail, name) values ('1', 'sarah@leetcode.com', 'Sarah');
insert into Users (user_id, mail, name) values ('2', 'bob@leetcode.com', 'Bob');
insert into Users (user_id, mail, name) values ('3', 'alice@leetcode.com', 'Alice');
insert into Users (user_id, mail, name) values ('4', 'hercy@leetcode.com', 'Hercy');
insert into Users (user_id, mail, name) values ('5', 'quarz@leetcode.com', 'Quarz');

输入表

contests表

 users表

分析数据

分析一:为了容易连接,将金牌,银牌,铜牌设置成一列。

select contest_id,'gold' type,gold_medal user_id from contestsunion allselect contest_id,'silver' type,silver_medal user_id from contestsunion allselect contest_id,'bronze' type,bronze_medal user_id from contests

 分析二:该用户连续三场及更多比赛中赢得任意奖牌

​
with t as (select contest_id,'gold' type,gold_medal user_id from contestsunion allselect contest_id,'silver' type,silver_medal user_id from contestsunion allselect contest_id,'bronze' type,bronze_medal user_id from contests
), t1 as (select t1.user_id from t t1,t t2,t t3where t1.user_id = t2.user_id and t2.user_id = t3.user_idand t1.contest_id + 1 = t2.contest_id and t2.contest_id + 1 = t3.contest_id)
select * from t1;​

分析三: 该用户在三场及更多不同的比赛中赢得金牌(可不连续)

with t as (select contest_id,'gold' type,gold_medal user_id from contestsunion allselect contest_id,'silver' type,silver_medal user_id from contestsunion allselect contest_id,'bronze' type,bronze_medal user_id from contests
)select user_id from t where type = 'gold' group by user_id having count(*) >= 3;

 实现代码

with t as (select contest_id,'gold' type,gold_medal user_id from contestsunion allselect contest_id,'silver' type,silver_medal user_id from contestsunion allselect contest_id,'bronze' type,bronze_medal user_id from contests
), t1 as (select t1.user_id from t t1,t t2,t t3where t1.user_id = t2.user_id and t2.user_id = t3.user_idand t1.contest_id + 1 = t2.contest_id and t2.contest_id + 1 = t3.contest_id), t2 as (select user_id from t where type = 'gold' group by user_id having count(*) >= 3
), t3 as (select user_id from t1 union select user_id from t2
)
select u.name,u.mail from t3 , users u where t3.user_id = u.user_id;

总结

  1. 如果一张表中出现多个列可以与另一张表进行关联,可以把多个列利用union all连接成一个列,最后进行关联条件。

  2. 出现两个互不关联的条件,可以分别求出,最后再利用union 进行连接

  3. union或者union all是多个select语句进行连接的,且每个select语句字段个数和顺序需一致

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 网络编程(学习)2024.8.27
  • 书生大模型实战营闯关记录----第十一关:LMDeploy 量化部署进阶实践 KV cache量化部署,W4A16 模型量化和部署
  • 数字化转型中的数据应用:挑战、机遇与追赶之路
  • sql高并发如何解决
  • 【vue3】wangEditor 5在vue3中的使用
  • 基于my Batis优化图书管理系统(总)
  • 【搜索引擎】ElasticSearch 7.x版本
  • ACL基础笔记
  • ceph-rgw zipper的设计理念(1)
  • ARCGIS 纸质小班XY坐标转电子要素面(2)
  • validationtools中按键测试选项光标移除
  • Spring Boot集成Stripe快速入门demo
  • 使用dx工具将jar和class打包成dex
  • 注解的生命周期
  • 粘包、半包和Netty中的自定义帧解码器间的关系
  • 【跃迁之路】【641天】程序员高效学习方法论探索系列(实验阶段398-2018.11.14)...
  • ComponentOne 2017 V2版本正式发布
  • CSS3 变换
  • JavaScript服务器推送技术之 WebSocket
  • Object.assign方法不能实现深复制
  • Protobuf3语言指南
  • 基于阿里云移动推送的移动应用推送模式最佳实践
  • ------- 计算机网络基础
  • 七牛云假注销小指南
  • 如何进阶一名有竞争力的程序员?
  • 实战:基于Spring Boot快速开发RESTful风格API接口
  • 手写一个CommonJS打包工具(一)
  • 突破自己的技术思维
  • 在GitHub多个账号上使用不同的SSH的配置方法
  • ‌前端列表展示1000条大量数据时,后端通常需要进行一定的处理。‌
  • #【QT 5 调试软件后,发布相关:软件生成exe文件 + 文件打包】
  • #if 1...#endif
  • #免费 苹果M系芯片Macbook电脑MacOS使用Bash脚本写入(读写)NTFS硬盘教程
  • (SpringBoot)第二章:Spring创建和使用
  • (附源码)spring boot火车票售卖系统 毕业设计 211004
  • (附源码)计算机毕业设计ssm-Java网名推荐系统
  • (含react-draggable库以及相关BUG如何解决)固定在左上方某盒子内(如按钮)添加可拖动功能,使用react hook语法实现
  • (七)MySQL是如何将LRU链表的使用性能优化到极致的?
  • (三分钟了解debug)SLAM研究方向-Debug总结
  • (数据结构)顺序表的定义
  • (新)网络工程师考点串讲与真题详解
  • (一)十分简易快速 自己训练样本 opencv级联haar分类器 车牌识别
  • (原創) 博客園正式支援VHDL語法著色功能 (SOC) (VHDL)
  • *p=a是把a的值赋给p,p=a是把a的地址赋给p。
  • .bat批处理(二):%0 %1——给批处理脚本传递参数
  • .NET Core WebAPI中使用Log4net 日志级别分类并记录到数据库
  • .net core 实现redis分片_基于 Redis 的分布式任务调度框架 earth-frost
  • .net core 外观者设计模式 实现,多种支付选择
  • .NET 编写一个可以异步等待循环中任何一个部分的 Awaiter
  • .NET 应用架构指导 V2 学习笔记(一) 软件架构的关键原则
  • .net6+aspose.words导出word并转pdf
  • .NetCore实践篇:分布式监控Zipkin持久化之殇
  • .NET开源项目介绍及资源推荐:数据持久层 (微软MVP写作)
  • .NET平台开源项目速览(15)文档数据库RavenDB-介绍与初体验
  • ::before和::after 常见的用法