0

我有一个看起来像这样的表(称为“会话”):

user_id | action | datetime  
1       |  1     |  2015-12-06 20:15:46  
1       |  2     |  2015-12-06 20:15:56  
2       |  1     |  2015-12-06 10:01:36  
2       |  2     |  2015-12-06 10:01:39  
1       |  1     |  2015-12-07 18:17:46  
1       |  2     |  2015-12-07 18:17:56  
2       |  1     |  2015-12-07 14:03:46  
2       |  2     |  2015-12-07 14:03:49  

我想使用 mysql 来计算每个用户在每个活动上花费的秒数(“持续时间”),这是给定一天给定 user_id 的日期时间之间的差异,得到:

user_id |  action |  datetime             | duration  
1       |   1     |   2015-12-06 20:15:46 |      10  
1       |   2     |   2015-12-06 20:15:56 |      NaN  
2       |   1     |   2015-12-06 10:01:36 |      3         
2       |   2     |   2015-12-06 10:01:39 |      NaN 

我可以使它适用于系列,但不适用于面板。谢谢!

4

2 回答 2

1

解决方案包括两次穿越同一张表,一个对应于发生的“第一个动作”,另一个对应于“下一个动作”。然后可以在查询的“on”部分中表达要求:

select first_action.user_id, 
       first_action.action, 
       first_action.datetime,
       (next_action.datetime - first_action.datetime) duration
  from
  (select * from sessions) as first_action 
  left outer join (select * from sessions) as next_action
  on first_action.user_id = next_action.user_id
  and first_action.action + 1 = next_action.action
  and date(first_action.datetime) = date(next_action.datetime);
于 2015-12-07T23:32:02.067 回答
1

例如像...

SELECT x.user_id
     , x.action
     , x.datetime start
     , y.datetime stop
     , TIMEDIFF(y.datetime,x.datetime) duration 
  FROM my_table x 
  LEFT 
  JOIN my_table y 
    ON y.user_id = x.user_id 
   AND DATE(y.datetime) = DATE(x.datetime) 
   AND y.action = 2 
 WHERE x.action = 1 
 ORDER 
    BY user_id
     , start;
于 2015-12-08T00:00:41.407 回答