3308. 寻找表现最佳的司机 🔒
题目描述
表:Drivers
+--------------+---------+ | Column Name | Type | +--------------+---------+ | driver_id | int | | name | varchar | | age | int | | experience | int | | accidents | int | +--------------+---------+ (driver_id) 是这张表的唯一主键。 每一行包含一个司机 ID,他们的名字,年龄,驾龄年数,以及事故数。
表:Vehicles
+--------------+---------+ | vehicle_id | int | | driver_id | int | | model | varchar | | fuel_type | varchar | | mileage | int | +--------------+---------+ (vehicle_id, driver_id, fuel_type) 是这张表的唯一主键。 每一行包含机动车 ID,驾驶员,车型,动力类型和里程数。
表:Trips
+--------------+---------+ | trip_id | int | | vehicle_id | int | | distance | int | | duration | int | | rating | int | +--------------+---------+ (trip_id) 是这张表的唯一主键。 每一行包含行程 ID,使用的机动车,覆盖的距离(以米计),行程市场(以分钟计),以及乘客评分(1-5)。
优步正在基于司机的行程分析他们的情况。编写一个解决方案,根据下列标准来找到 每种动力类型 中 表现最好的司机:
- 一个司机的表现由他们行程的 平均评分 计算。平均评分应该舍入到
2
位小数。 - 如果两个司机有相同的平均评分,里程数更多 的司机评分更高。
- 如果 依旧持平,选择 事故数最少 的司机。
返回结果表以 fuel_type
升序 排序。
结果格式如下所示。
示例:
输入:
Drivers
表:
+-----------+----------+-----+------------+-----------+ | driver_id | name | age | experience | accidents | +-----------+----------+-----+------------+-----------+ | 1 | Alice | 34 | 10 | 1 | | 2 | Bob | 45 | 20 | 3 | | 3 | Charlie | 28 | 5 | 0 | +-----------+----------+-----+------------+-----------+
Vehicles
表:
+------------+-----------+---------+-----------+---------+ | vehicle_id | driver_id | model | fuel_type | mileage | +------------+-----------+---------+-----------+---------+ | 100 | 1 | Sedan | Gasoline | 20000 | | 101 | 2 | SUV | Electric | 30000 | | 102 | 3 | Coupe | Gasoline | 15000 | +------------+-----------+---------+-----------+---------+
Trips
表:
+---------+------------+----------+----------+--------+ | trip_id | vehicle_id | distance | duration | rating | +---------+------------+----------+----------+--------+ | 201 | 100 | 50 | 30 | 5 | | 202 | 100 | 30 | 20 | 4 | | 203 | 101 | 100 | 60 | 4 | | 204 | 101 | 80 | 50 | 5 | | 205 | 102 | 40 | 30 | 5 | | 206 | 102 | 60 | 40 | 5 | +---------+------------+----------+----------+--------+
输出:
+-----------+-----------+--------+----------+ | fuel_type | driver_id | rating | distance | +-----------+-----------+--------+----------+ | Electric | 2 | 4.50 | 180 | | Gasoline | 3 | 5.00 | 100 | +-----------+-----------+--------+----------+
解释:
- 对于动力类型
Gasoline
,Alice(司机 1)和 Charlie(司机 3)有行程。Charlie 平均评分为 5.0,而 Alice 为 4.5。因此,选择 Charlie。 - 对于动力类型
Electric
,Bob(司机 2)是唯一的司机,评分为 4.5,因此选择他。
输出表以 fuel_type
升序排序。
解法
方法一:等值连接 + 分组 + 窗口函数
我们可以使用等值连接,将 Drivers
表和 Vehicles
表按照 driver_id
连接,再与 Trips
表按照 vehicle_id
连接,然后按照 fuel_type
、driver_id
分组,计算每个司机的平均评分、总行驶里程、总事故次数,然后使用 RANK()
窗口函数,将每种燃料类型的司机按照评分降序、总行驶里程降序、总事故次数升序排名,最后筛选出每种燃料类型的排名为 1 的司机。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 |
|