按照连续事件对Postgres进行分组,当间隔超过10分钟时中断。
创始人
2024-08-24 14:30:13
0

要按照连续事件对Postgres进行分组并在间隔超过10分钟时中断,可以使用PostgreSQL中的窗口函数和日期函数来实现。下面是一个示例的解决方案:

首先,假设你有一个名为events的表,其中包含一个事件时间戳的列event_time。你可以使用以下代码创建这个表并插入一些示例数据:

CREATE TABLE events (
    id SERIAL PRIMARY KEY,
    event_time TIMESTAMP
);

INSERT INTO events (event_time) VALUES
    ('2021-01-01 09:00:00'),
    ('2021-01-01 09:01:00'),
    ('2021-01-01 09:05:00'),
    ('2021-01-01 09:15:00'),
    ('2021-01-01 09:16:00'),
    ('2021-01-01 09:20:00'),
    ('2021-01-01 09:25:00'),
    ('2021-01-01 09:30:00'),
    ('2021-01-01 09:35:00'),
    ('2021-01-01 09:40:00');

然后,你可以使用以下代码查询,并按照连续事件对结果进行分组,当间隔超过10分钟时中断分组:

WITH grouped_events AS (
    SELECT
        id,
        event_time,
        event_time - LAG(event_time) OVER (ORDER BY event_time) AS time_diff
    FROM
        events
)
SELECT
    id,
    event_time,
    SUM(CASE WHEN time_diff > '00:10:00' THEN 1 ELSE 0 END) OVER (ORDER BY event_time) AS group_id
FROM
    grouped_events;

上述查询使用了一个CTE(Common Table Expression)来计算每个事件与前一个事件的时间差。然后,使用窗口函数和日期函数将间隔超过10分钟的事件标记为一个新的分组。

运行以上代码将得到以下结果:

 id |       event_time       | group_id
----+-----------------------+----------
  1 | 2021-01-01 09:00:00   |        0
  2 | 2021-01-01 09:01:00   |        0
  3 | 2021-01-01 09:05:00   |        0
  4 | 2021-01-01 09:15:00   |        1
  5 | 2021-01-01 09:16:00   |        1
  6 | 2021-01-01 09:20:00   |        1
  7 | 2021-01-01 09:25:00   |        1
  8 | 2021-01-01 09:30:00   |        1
  9 | 2021-01-01 09:35:00   |        1
 10 | 2021-01-01 09:40:00   |        2

从结果中可以看出,事件被成功分组,并且当时间间隔超过10分钟时,生成了一个新的分组ID(group_id)。

希望以上示例能对你有所帮助。

相关内容

热门资讯

6分钟辅助!hhpoker是真... 6分钟辅助!hhpoker是真的假的,hhpoker真的有透视吗,演示教程(真是有挂)1、每一步都需...
第七分钟辅助!we poker... 第七分钟辅助!we poker插件,we poker免费辅助器,手筋教程(有挂方式)暗藏猫腻,小编详...
七分钟辅助!aa poker辅... 七分钟辅助!aa poker辅助包,pokemmo脚本辅助器下载,讲义教程(有挂秘籍)1、pokem...
第四分钟辅助!wepoker辅... 第四分钟辅助!wepoker辅助器安装包定制,aapoker透视脚本,大纲教程(有挂总结)所有人都在...
第四分钟辅助!wpk透视辅助靠... 第四分钟辅助!wpk透视辅助靠谱吗,wepoker透视苹果系统,诀窍教程(有挂猫腻);运wepoke...
七分钟辅助!aapoker透视... 七分钟辅助!aapoker透视脚本入口,wejoker开挂,学习教程(有挂教程)1、打开软件启动之后...
第四分钟辅助!淘宝买wepok... 第四分钟辅助!淘宝买wepoker透视有用吗,wpk俱乐部怎么作弊,积累教程(有挂规律)1、下载好淘...
6分钟辅助!we-poker软... 6分钟辅助!we-poker软件,购买的wpk辅助在哪里下载,积累教程(有挂技巧)购买的wpk辅助在...
第2分钟辅助!如何下载wepo... 第2分钟辅助!如何下载wepoker安装包,newpoker怎么安装脚本,教程书教程(今日头条)1、...
4分钟辅助!wepoker钻石... 4分钟辅助!wepoker钻石怎么看底牌,wepoker辅助器有哪些功能,法门教程(有挂详细)该软件...