力扣之1783.大满贯数量

文章目录

  • [1. 1783.大满贯数量](#1. 1783.大满贯数量)
    • [1.1 题干](#1.1 题干)
    • [1.2 建表](#1.2 建表)
    • [1.3 题解](#1.3 题解)
    • [1.4 结果截图](#1.4 结果截图)

1. 1783.大满贯数量

1.1 题干

表:Players

±---------------±--------+

| Column Name | Type |

±---------------±--------+

| player_id | int |

| player_name | varchar |

±---------------±--------+

player_id 是这个表的主键(具有唯一值的列)

这个表的每一行给出一个网球运动员的 ID 和 姓名

表:Championships

±--------------±--------+

| Column Name | Type |

±--------------±--------+

| year | int |

| Wimbledon | int |

| Fr_open | int |

| US_open | int |

| Au_open | int |

±--------------±--------+

year 是这个表的主键(具有唯一值的列)

该表的每一行都包含在每场大满贯网球比赛中赢得比赛的球员的 ID

编写解决方案,找出每一个球员赢得大满贯比赛的次数。结果不包含没有赢得比赛的球员的ID 。

结果集 无顺序要求 。

结果的格式,如下所示。

示例 1:

输入:

Players 表:

±----------±------------+

| player_id | player_name |

±----------±------------+

| 1 | Nadal |

| 2 | Federer |

| 3 | Novak |

±----------±------------+

Championships 表:

±-----±----------±--------±--------±--------+

| year | Wimbledon | Fr_open | US_open | Au_open |

±-----±----------±--------±--------±--------+

| 2018 | 1 | 1 | 1 | 1 |

| 2019 | 1 | 1 | 2 | 2 |

| 2020 | 2 | 1 | 2 | 2 |

±-----±----------±--------±--------±--------+

输出:

±----------±------------±------------------+

| player_id | player_name | grand_slams_count |

±----------±------------±------------------+

| 2 | Federer | 5 |

| 1 | Nadal | 7 |

±----------±------------±------------------+

解释:

Player 1 (Nadal) 获得了 7 次大满贯:其中温网 2 次(2018, 2019), 法国公开赛 3 次 (2018, 2019, 2020), 美国公开赛 1 次 (2018)以及澳网公开赛 1 次 (2018) 。

Player 2 (Federer) 获得了 5 次大满贯:其中温网 1 次 (2020), 美国公开赛 2 次 (2019, 2020) 以及澳网公开赛 2 次 (2019, 2020) 。

Player 3 (Novak) 没有赢得,因此不包含在结果集中。

1.2 建表

复制代码
Create table If Not Exists Players (player_id int, player_name varchar(20))
Create table If Not Exists Championships (year int, Wimbledon int, Fr_open int, US_open int, Au_open int)
Truncate table Players
insert into Players (player_id, player_name) values ('1', 'Nadal')
insert into Players (player_id, player_name) values ('2', 'Federer')
insert into Players (player_id, player_name) values ('3', 'Novak')
Truncate table Championships
insert into Championships (year, Wimbledon, Fr_open, US_open, Au_open) values ('2018', '1', '1', '1', '1')
insert into Championships (year, Wimbledon, Fr_open, US_open, Au_open) values ('2019', '1', '1', '2', '2')
insert into Championships (year, Wimbledon, Fr_open, US_open, Au_open) values ('2020', '2', '1', '2', '2')

1.3 题解

复制代码
select p.player_id,
       p.player_name,
       sum(player_id=wimbledon)+sum(player_id=fr_open)+sum(player_id=us_open)+sum(player_id=au_open) as grand_slams_count
from players p,championships c
group by p.player_id, p.player_name
having grand_slams_count>0
;

1.4 结果截图

相关推荐
liang_jy12 小时前
Android 窗口容器树(一)—— 窗口和窗口容器树
android·源码
HUGu RGIN12 小时前
MySQL--》如何在MySQL中打造高效优化索引
android·mysql·adb
wuminyu14 小时前
专家视角看Java字节码加载与存储指令机制
java·linux·c语言·jvm·c++
TDengine (老段)15 小时前
从施工监测到运营预警,桥科院用 TDengine 提升桥梁数据管理能力
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
宁波鹿语心理15 小时前
无条件的在场:一项极简亲子依恋修复练习的机制分析与实证观察
大数据
Joseph Cooper15 小时前
Linux/Android 跟踪技术:ftrace、TRACE_EVENT、atrace、systrace 与 perfetto 入门
android·linux·运维
Navigator_Z15 小时前
LeetCode //C - 1033. Moving Stones Until Consecutive
c语言·算法·leetcode
callJJ15 小时前
Spring Data Redis 两种编程模型详解:同步 vs 响应式
java·spring boot·redis·python·spring
空中海15 小时前
安卓逆向03. 动态调试、抓包分析与 Frida Hook
android
wbs_scy16 小时前
Linux线程同步与互斥(三):线程同步深度解析之POSIX 信号量与环形队列生产者消费者模型,从原理到源码彻底吃透
java·开发语言