按照连续事件对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)。

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

相关内容

热门资讯

记者揭秘!智星菠萝辅助(透视辅... 记者揭秘!智星菠萝辅助(透视辅助)拱趴大菠萝辅助神器,扑克教程(有挂细节);模式供您选择,了解更新找...
一分钟揭秘!约局吧能能开挂(透... 一分钟揭秘!约局吧能能开挂(透视辅助)hhpoker辅助靠谱,2024新版教程(有挂教学);约局吧能...
透视辅助!wepoker模拟器... 透视辅助!wepoker模拟器哪个好用(脚本)hhpoker辅助挂是真的,科技教程(有挂技巧);囊括...
透视代打!hhpkoer辅助器... 透视代打!hhpkoer辅助器视频(辅助挂)pokemmo脚本辅助,2024新版教程(有挂教程);风...
透视了解!约局吧德州真的有透视... 透视了解!约局吧德州真的有透视挂(透视脚本)德州局HHpoker透视脚本,必胜教程(有挂分析);亲,...
六分钟了解!wepoker挂底... 六分钟了解!wepoker挂底牌(透视)德普之星开辅助,详细教程(有挂解密);德普之星开辅助是一种具...
9分钟了解!wpk私人辅助(透... 9分钟了解!wpk私人辅助(透视)hhpoker德州透视,插件教程(有挂教学);风靡全球的特色经典游...
推荐一款!wepoker究竟有... 推荐一款!wepoker究竟有透视(脚本)哈糖大菠萝开挂,介绍教程(有挂技术);囊括全国各种wepo...
每日必备!wepoker有人用... 每日必备!wepoker有人用过(脚本)wpk有那种辅助,线上教程(有挂规律);wepoker有人用...
玩家必备教程!wejoker私... 玩家必备教程!wejoker私人辅助软件(脚本)哈糖大菠萝可以开挂,可靠技巧(有挂神器)申哈糖大菠萝...