SQL,生成指定时间间隔内的事件次序号

MSSQL 数据库某表有三个字段:账号、字符串类型的日期和时间。

|----------------|-------------------|-------------|
| Account_Number | FuelPurchase_Date | Fuel_TOD |
| 19 | 2024-04-03 | 07:02:02 AM |
| 19 | 2024-04-03 | 07:02:41 AM |
| 19 | 2024-04-03 | 02:58:49 PM |
| 19 | 2024-04-03 | 07:58:49 PM |
| 19 | 2024-04-05 | 02:58:49 PM |
| 19 | 2024-04-05 | 02:59:31 PM |
| 19 | 2024-04-17 | 11:56:13 PM |
| 20 | 2024-04-17 | 11:59:13 PM |
| 19 | 2024-04-18 | 12:15:13 AM |
| 19 | 2024-04-18 | 02:56:13 PM |
| 20 | 2024-04-18 | 07:41:55 AM |
| 20 | 2024-04-18 | 07:41:55 PM |
| 20 | 2024-04-18 | 07:56:55 PM |
| 19 | 2024-04-19 | 07:41:55 AM |
| 19 | 2024-04-19 | 07:42:20 AM |
| 19 | 2024-04-19 | 08:41:20 AM |

现在要新增一个分组的序号列 Seq,当某个账号在一个小时内发生新事件时,Seq+1;如果一个小时后才发生新事件,则重置 Seq 为 1。

|----------------|-------------------|-------------|-----|
| Account_Number | FuelPurchase_Date | Fuel_TOD | Seq |
| 19 | 2024-04-03 | 07:02:02 AM | 1 |
| 19 | 2024-04-03 | 07:02:41 AM | 2 |
| 19 | 2024-04-03 | 02:58:49 PM | 1 |
| 19 | 2024-04-03 | 07:58:49 PM | 1 |
| 19 | 2024-04-05 | 02:58:49 PM | 1 |
| 19 | 2024-04-05 | 02:59:31 PM | 2 |
| 19 | 2024-04-17 | 11:56:13 PM | 1 |
| 19 | 2024-04-18 | 12:15:13 AM | 2 |
| 19 | 2024-04-18 | 02:56:13 PM | 1 |
| 19 | 2024-04-19 | 07:41:55 AM | 1 |
| 19 | 2024-04-19 | 07:42:20 AM | 2 |
| 19 | 2024-04-19 | 08:41:20 AM | 3 |
| 20 | 2024-04-17 | 11:59:13 PM | 1 |
| 20 | 2024-04-18 | 07:41:55 AM | 1 |
| 20 | 2024-04-18 | 07:41:55 PM | 1 |
| 20 | 2024-04-18 | 07:56:55 PM | 2 |

编写SPL代码

|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| |  A |
| 1 | =mssql.query("select *,cast(FuelPurchase_Date as datetime) + cast(Fuel_TOD as datetime) as DT from tb order by Account_Number,DT") |
| 2 | =A1.new(Account_Number,FuelPurchase_Date,Fuel_TOD, if(Account_Number==Account_Number-1 && interval@s(Fuel_DT-1,Fuel_DT)<3600,Seq-1+1,1):Seq) |

A1:通过JDBC查询数据库,拼出日期时间类型的计算列DT,并按账号和DT排序。

A2:新建二维表,增加新计算列Seq。当前记录的账号与上一条记录相同,且时间间隔一小时内时,Seq+1;否则将Seq重置为1。-1表示相对位置的上一条记录。

SPL已开源免费,欢迎前往乾学院社区了解更多!

SPL源码地址

免费下载

相关推荐
倔强的石头_7 分钟前
《Kingbase护城河》——猎捕慢查询:执行计划的微观解析与索引调优实战
数据库
SelectDB2 小时前
Apache Doris Python UDF:让 SQL 直接调用 Python 生态,支撑 Agent 时代复杂业务逻辑
大数据·数据库·python
jiayou641 天前
KingbaseES 表级与列级加密完全指南
数据库·后端
GBASE2 天前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
xiezhr2 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
唐青枫3 天前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
吃糖的小孩3 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
笃行3504 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3504 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3504 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库