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

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

相关内容

热门资讯

推荐一款(中至常熟麻将技巧)本... 您好,中至常熟麻将技巧这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在...
盘点几款(天天贵阳手机麻将通用... 盘点几款(天天贵阳手机麻将通用胡牌神器)往昔真的有挂(辅助挂)2025版教程(2026已更新)(哔哩...
一分钟教你(豆豆斗牌辅助器)确... 一分钟教你(豆豆斗牌辅助器)确实是有挂(辅助挂)揭秘教程(2021已更新)(哔哩哔哩);豆豆斗牌辅助...
一分钟快速了解(手机唯思竞技麻... 一分钟快速了解(手机唯思竞技麻将有挂)起初真的是有挂(辅助挂)技巧教程(2022已更新)(哔哩哔哩)...
最新研发(浙江游戏大厅插件)先... 您好,浙江游戏大厅插件这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在...
必知教程(大盘山棋牌有挂)好像... 必知教程(大盘山棋牌有挂)好像存在有挂(辅助挂)详细教程(2025已更新)(哔哩哔哩);大盘山棋牌有...
重磅来袭(山西大唐麻将系统规律... 重磅来袭(山西大唐麻将系统规律)确实是真的有挂(辅助挂)细节揭秘(2021已更新)(哔哩哔哩);超受...
大神推荐(哈哈长沙麻将可以提高... 大神推荐(哈哈长沙麻将可以提高胜率)总是有挂(辅助挂)揭秘教程(2023已更新)(哔哩哔哩);1、选...
发现一款(大齐山东麻将有挂)确... 您好,大齐山东麻将有挂这款游戏可以开挂的,确实是有挂的,需要了解加微【485275054】很多玩家在...
分享一款(浙江游戏大厅游戏外挂... 【福星临门,好运相随】;分享一款(浙江游戏大厅游戏外挂)往昔存在有挂(辅助挂)透牌教程(2021已更...