天天看點

SQL練習:查詢近30天活躍使用者數

題目描述

活動記錄表: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