两次活动之间的时间

时间:2016-09-08 09:47:28

标签: sql postgresql

如果有一个表跟踪用户的某些事件。

 id | user_id | action |         created_at         
----+---------+--------+----------------------------
  5 |       1 | create | 2016-09-08 11:29:56.325691
  6 |       1 | clear  | 2016-09-08 11:30:00.08604
  7 |       2 | create | 2016-09-08 11:30:10.12857
  8 |       2 | clear  | 2016-09-08 11:30:14.238685
  9 |       3 | create | 2016-09-08 11:30:42.192843

始终有一个create操作可能会跟随clear操作。

CREATE TYPE user_actions AS ENUM ('create', 'clear');

现在,我想查询这两个操作之间的时差,以便在用户的createclear之间获得time_diff。

现在,您可以假设user没有多个条目(例如,至少有一个create和另一个clear

我想得到这样的结果:

 user_id |    time_diff    
---------+-----------------
       1 | 00:00:03.760349
       2 | 00:00:04.110115

1 个答案:

答案 0 :(得分:1)

您可以使用以下查询:

SELECT user_id,
       MAX(CASE WHEN action = 'clear' THEN created_at END) -
       MAX(CASE WHEN action = 'create' THEN created_at END) AS time_diff 
FROM mytable
GROUP BY user_id 
HAVING COUNT(*) = 2

HAVING子句过滤掉仅包含user_id操作的create个群组,例如OP中的id=9记录。

Demo here