題目描述
活動記錄表:Activity
+---------------+---------+
| Column Name | Type |
+---------------+---------+
| user_id | int |
| session_id | int |
| activity_date | date |
| activity_type | enum |
+---------------+---------+
該表是使用者在社交網站的活動記錄。
該表沒有主鍵,可能包含重複資料。
activity_type 字段為以下四種值 ('open_session', 'end_session', 'scroll_down', 'send_message')。
每個 session_id 隻屬于一個使用者。
請寫SQL查詢出截至 2019-07-27(包含2019-07-27),近 30 天的每日活躍使用者數(當天隻要有一條活動記錄,即為活躍使用者)。
以 任意順序 傳回結果表。查詢結果示例如下:
輸入:
Activity table:
+---------+------------+---------------+---------------+
| user_id | session_id | activity_date | activity_type |
+---------+------------+---------------+---------------+
| 1 | 1 | 2019-07-20 | open_session |
| 1 | 1 | 2019-07-20 | scroll_down |
| 1 | 1 | 2019-07-20 | end_session |
| 2 | 4 | 2019-07-20 | open_session |
| 2 | 4 | 2019-07-21 | send_message |
| 2 | 4 | 2019-07-21 | end_session |
| 3 | 2 | 2019-07-21 | open_session |
| 3 | 2 | 2019-07-21 | send_message |
| 3 | 2 | 2019-07-21 | end_session |
| 4 | 3 | 2019-06-25 | open_session |
| 4 | 3 | 2019-06-25 | end_session |
+---------+------------+---------------+---------------+
輸出:
+------------+--------------+
| day | active_users |
+------------+--------------+
| 2019-07-20 | 2 |
| 2019-07-21 | 2 |
+------------+--------------+
解釋:注意非活躍使用者的記錄不需要展示。
求解
select
activity_date day,count(distinct user_id) active_users
from activity
where
activity_date between '2019-06-28' and '2019-07-27'
group by
activity_date