LeetCode--2298. 周末任务计数

文章目录

  • 1 题目描述
  • 2 测试用例
  • 3 解题思路

1 题目描述

表: Tasks

+-------------+------+
| Column Name | Type |
+-------------+------+
| task_id     | int  |
| assignee_id | int  |
| submit_date | date |
+-------------+------+

task_id 是该表的主键(具有唯一值的列)。
此表中的每一行都包含任务 ID、委托人 ID 和提交日期。

编写一个解决方案来报告:

  • 在周末 (周六,周日) 提交的任务的数量 weekend_cnt,以及
  • 工作日内提交的任务数 working_cnt

任意顺序 返回结果表。

2 测试用例

输入:

Tasks 表:

+---------+-------------+-------------+
| task_id | assignee_id | submit_date |
+---------+-------------+-------------+
| 1       | 1           | 2022-06-13  |
| 2       | 6           | 2022-06-14  |
| 3       | 6           | 2022-06-15  |
| 4       | 3           | 2022-06-18  |
| 5       | 5           | 2022-06-19  |
| 6       | 7           | 2022-06-19  |
+---------+-------------+-------------+

输出:

+-------------+-------------+
| weekend_cnt | working_cnt |
+-------------+-------------+
| 3           | 3           |
+-------------+-------------+

解释:
Task 1 是在周一提交的。
Task 2 是在周二提交的。
Task 3 是在周三提交的。
Task 4 是在周六提交的。
Task 5 是在周日提交的。
Task 6 是在周日提交的。
3 个任务是在周末提交的。
3 个任务是在工作日提交的。

3 解题思路

  1. 使用 WEEKDAY 计算 submit_date 的是星期几,WEEKDAY(submit_date) + 1 计算得到的数字就是星期几,1 对应星期一,以此类推 6 对应星期六, 7 对应星期天,然后使用 sum 统计工作日 和 周末的订单数量
select sum(if(WEEKDAY(submit_date) + 1 >= 6, 1, 0)) as weekend_cnt,  
       sum(if(WEEKDAY(submit_date) + 1 <= 5, 1, 0))  as working_cnt  
from Tasks

执行结果

+-----------+-----------+
|weekend_cnt|working_cnt|
+-----------+-----------+
|3          |3          |
+-----------+-----------+

你可能感兴趣的:(MySQL,LeetCode,leetcode,算法,mysql)