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

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

相关内容

热门资讯

揭秘关于!wepoke app... 1、揭秘关于!wepoke app(wepoke)外挂透明挂辅助器(透视)解密教程(真实有挂)-哔哩...
玩家必备教程(扑克时间)外挂透... 玩家必备教程(扑克时间)外挂透明挂辅助工具(辅助挂)透视辅助(2025已更新)(哔哩哔哩);亲,其实...
科普攻略(gg扑克平台)外挂透... 【福星临门,好运相随】;科普攻略(gg扑克平台)外挂透明挂辅助脚本(透视)透视辅助(有挂秘籍)-哔哩...
程序员教你!云扑克德州(wep... 程序员教你!云扑克德州(wepOKE)外挂透明挂辅助工具(透视)透明挂教程(有挂教学)-哔哩哔哩;云...
玩家实测(WPK线上)外挂透明... 玩家实测(WPK线上)外挂透明挂辅助脚本(辅助挂)软件透明挂(2025已更新)(哔哩哔哩)相信很多朋...
透视好友(wpk德州俱乐部)外... 透视好友(wpk德州俱乐部)外挂透明挂辅助挂(透视)透视辅助(有挂方式)-哔哩哔哩;(需添加指定薇4...
玩家必备教程!wpk实锤(we... 相信很多朋友都在电脑上玩过wpk实锤吧,但是很多朋友都在抱怨用电脑玩起来不方便。为此小编给大家带来了...
总算了解(Wepoke德州版)... 总算了解(Wepoke德州版)外挂透明挂辅助APP(辅助挂)透视辅助(2023已更新)(哔哩哔哩);...
玩家必看科普(wpk德州辅助器... 玩家必看科普(wpk德州辅助器)外挂透明挂辅助app(辅助挂)发牌机制(了解有挂)-哔哩哔哩1、不需...
4分钟了解!WEPOKE(we... 4分钟了解!WEPOKE(wepoke)外挂透明挂辅助工具(辅助挂)解密教程(有挂技巧)-哔哩哔哩1...