3118. 发生在周五的交易 III 🔒
题目描述
表:Purchases
+---------------+------+ | Column Name | Type | +---------------+------+ | user_id | int | | purchase_date | date | | amount_spend | int | +---------------+------+ (user_id, purchase_date, amount_spend) 是该表的主键(具有唯一值的列)。 purchase_date 的范围从 2023 年 11 月 1 日到 2023 年 11 月 30 日,并包括这两个日期。 每一行包含 user_id, purchase_date,和 amount_spend。
表:Users
+-------------+------+
| Column Name | Type |
+-------------+------+
| user_id     | int  |
| membership  | enum |
+-------------+------+
user_id 是这张表的主键。
membership 是 ('Standard', 'Premium', 'VIP') 的枚举类型。
这张表的每一行表示 user_id 和会员类型。
编写一个解决方案来计算 Premium 和 VIP 会员在 2023 年 11 月 每周的周五 的 总花费。如果某个周五没有 Premium 或 VIP 会员购买,把它当作 0。
按照每月的周次序 升序 排列结果表,然后以 membership 升序 排序。
结果格式如下所示。
示例:
输入:
Purchases 表:
+---------+---------------+--------------+ | user_id | purchase_date | amount_spend | +---------+---------------+--------------+ | 11 | 2023-11-03 | 1126 | | 15 | 2023-11-10 | 7473 | | 17 | 2023-11-17 | 2414 | | 12 | 2023-11-24 | 9692 | | 8 | 2023-11-24 | 5117 | | 1 | 2023-11-24 | 5241 | | 10 | 2023-11-22 | 8266 | | 13 | 2023-11-21 | 12000 | +---------+---------------+--------------+
Users 表:
+---------+------------+ | user_id | membership | +---------+------------+ | 11 | Premium | | 15 | VIP | | 17 | Standard | | 12 | VIP | | 8 | Premium | | 1 | VIP | | 10 | Standard | | 13 | Premium | +---------+------------+
输出:
+---------------+-------------+--------------+
| week_of_month | membership  | total_amount |
+---------------+-------------+--------------+
| 1             | Premium     | 1126         |
| 1             | VIP         | 0            |
| 2             | Premium     | 0            |
| 2             | VIP         | 7473         |
| 3             | Premium     | 0            |
| 3             | VIP         | 0            |
| 4             | Premium     | 5117         |
| 4             | VIP         | 14933        |
+---------------+-------------+--------------+
        
解释:
- 在 2023 年 11 月的第一周,周五有一笔交易,2023-11-03,由一个 Premium 会员花费了 $1,126。这天没有 VIP 会员交易,所以值为 0。
 - 在 2023 年 11 月的第二周,周五有一笔交易,2023-11-10,由一个 VIP 会员花费了 $7,473。因为这条没有 Premium 会员交易,Premium 会员的输出为 0。
 - 相似地,在 2023 年 11 月的第三周,周五没有 Premium 或 VIP 会员交易,2023-11-17,所以这周两种分类都输出 0。
 - 在 2023 年 11 月的第四周,周五存在交易,2023-11-24,有一名 Premium 会员购买了 $5,117 以及 VIP 会员购买了总共 $14,933(一个花费 $9,692,另一个花费 $5,241)。
 
注意:输出表以 week_of_month 和 membership 升序排序。
解法
方法一:递归 + 连接
我们首先创建一个递归表 T,其中包含 week_of_month 列,表示月份的第几周。然后创建一个表 M,包含 membership 列,表示会员类型,取值为 'Premium' 和 'VIP'。
接着创建一个表 P,包含 week_of_month、membership 和 amount_spend 列,筛选出每个会员在每个月的第几周的周五的消费金额。最后,我们将 T 和 M 表连接,再左连接 P 表,并且按照 week_of_month 和 membership 列进行分组,计算每周每种会员的总消费金额。
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  |  |