-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathCreate a Session Bar Chart 25-10-22
More file actions
59 lines (45 loc) · 2.17 KB
/
Create a Session Bar Chart 25-10-22
File metadata and controls
59 lines (45 loc) · 2.17 KB
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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
link --------- https://www.codingninjas.com/codestudio/problems/create-a-session-bar-chart_2117111?topList=top-100-sql-problems&leftPanelTab=0
Problem Statement
Table: Sessions
+---------------------+---------+
| Column Name | Type |
+---------------------+---------+
| session_id | int |
| duration | int |
+---------------------+---------+
session_id is the primary key for this table.
duration is the time in seconds that a user has visited the application.
You want to know how long a user visits your application. You decided to create bins of "[0-5>", "[5-10>", "[10-15>" and "15 minutes or more" and count the number of sessions on it.
Write an SQL query to report the (bin, total) in any order.
The query result format is in the following example.
Sessions table:
+-------------+---------------+
| session_id | duration |
+-------------+---------------+
| 1 | 30 |
| 2 | 199 |
| 3 | 299 |
| 4 | 580 |
| 5 | 1000 |
+-------------+---------------+
Result table:
+--------------+--------------+
| bin | total |
+--------------+--------------+
| [0-5> | 3 |
| [5-10> | 1 |
| [10-15> | 0 |
| 15 or more | 1 |
+--------------+--------------+
For session_id 1, 2 and 3 have a duration greater or equal than 0 minutes and less than 5 minutes.
For session_id 4 has a duration greater or equal than 5 minutes and less than 10 minutes.
There are no session with a duration greater or equial than 10 minutes and less than 15 minutes.
For session_id 5 has a duration greater or equal than 15 minutes.
----------------------------------------- solution --------------------------------------
select '[0-5>' as bin , count(duration) total from sessions where duration < 300
union
select '[5-10>' as bin , count(duration) total from sessions where duration between 300 and 599
union
select '[10-15>' as bin , count(duration) total from sessions where duration between 600 and 899
union
select '15 or more' as bin , count(duration) total from sessions where duration >900