概述
假设有一张表,记录了用户的登入、登出信息,我们需要根据这些信息统计用户的在线时长,相应的设置用户等级,就像挂QQ升级
数据如下:
mysql> select * from user_sessions;
+----+----------+-------+----------+----------+
| id | platform | usr | start | end |
+----+----------+-------+----------+----------+
| 1 | web | user1 | 08:30:00 | 10:30:00 |
| 2 | web | user2 | 08:30:00 | 08:45:00 |
| 3 | web | user1 | 09:00:00 | 09:30:00 |
| 4 | web | user2 | 09:15:00 | 10:30:00 |
| 5 | web | user1 | 09:15:00 | 09:30:00 |
| 6 | web | user2 | 10:30:00 | 14:30:00 |
| 7 | web | user1 | 10:45:00 | 11:30:00 |
| 8 | web | user2 | 11:00:00 | 12:30:00 |
| 9 | app | user1 | 08:30:00 | 08:45:00 |
| 10 | app | user2 | 09:00:00 | 09:30:00 |
| 11 | app | user1 | 11:45:00 | 12:00:00 |
| 12 | app | user2 | 12:30:00 | 14:00:00 |
| 13 | app | user1 | 12:45:00 | 13:30:00 |
| 14 | app | user2 | 13:00:00 | 14:00:00 |
| 15 | app | user1 | 14:00:00 | 16:30:00 |
| 16 | app | user2 | 15:30:00 | 17:00:00 |
+----+----------+-------+----------+----------+
我们的站点有两个入口:web端和app端
很明显,这些数据时间上是有重叠的,例如user1在08:30~10:30这个时间段内用三个web端和一个app端登录,但他的时长应该只能算作2个小时
要正确统计,我们需要三步:
获取用户的重叠时间段中最早的起始时间
获取用户的重叠时间段中最晚的结束时间
前两步的起始时间与结束时间合并,得到综合的时间段,再进行统计
第一步:
查询用户名、起始时间
其中起始时间需要满足的条件是:不包含于其