如果有一个表跟踪用户的某些事件。
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');
现在,我想查询这两个操作之间的时差,以便在用户的create
和clear
之间获得time_diff。
现在,您可以假设user
没有多个条目(例如,至少有一个create
和另一个clear
。
我想得到这样的结果:
user_id | time_diff
---------+-----------------
1 | 00:00:03.760349
2 | 00:00:04.110115
答案 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
记录。