SQL,查询每天最接近指定时间的记录

Oracle 数据库的某表有一列是日期时间类型,每天对应多条数据:

|---------------------|---|
| t | d |
| 1.1.2024 08:08:08 | 1 |
| 1.1.2024 10:10:10 | 2 |
| 1.1.2024 15:15:15 | 3 |
| 1.1.2024 20:20:20 | 4 |
| 2.1.2024 09:09:09 | 5 |
| 2.1.2024 12:12:12 | 6 |
| 2.1.2024 16:16:16 | 7 |
| 12.12.2024 16:16:16 | 8 |

现在要从每天找出两条记录,一条离当天的早 8 点最近,一条离当天的晚 20 点最近。

|---------------------|---|
| t | d |
| 1.1.2024 08:08:08 | 1 |
| 1.1.2024 20:20:20 | 4 |
| 2.1.2024 09:09:09 | 5 |
| 2.1.2024 16:16:16 | 7 |
| 12.12.2024 16:16:16 | 8 |
| 12.12.2024 16:16:16 | 8 |

编写SPL代码

|---------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|
| |  A |
| 1 | =orcl.query("select * from tb") |
| 2 | =A1.group(day(t)) |
| 3 | =A2.conj([~.minp(abs(interval@s(time("08:00:00"),time(t)))),~.minp(abs(interval@s(time("20:00:00"),time(t))))]) |

A1:通过JDBC查询数据库。

A2:按日期分组,但不汇总,以便后续处理每组数据。

A3:对每组数据,计算组内每条记录与当天8点的间隔秒数,取绝对值,求绝对值最小的那条记录;同理算出来与20点间隔秒数的绝对值最小的记录;最后合并各组的处理结果。minp函数用于计算符合条件的最小的记录。

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

SPL源码地址

免费下载试用

相关推荐
q***816417 小时前
MySQL:数据查询-limit
数据库·mysql
p***924817 小时前
DBeaver连接本地MySQL、创建数据库表的基础操作
数据库·mysql
JIngJaneIL19 小时前
社区互助|社区交易|基于springboot+vue的社区互助交易系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·社区互助
晚风吹人醒.19 小时前
缓存中间件Redis安装及功能演示、企业案例
linux·数据库·redis·ubuntu·缓存·中间件
Y***985119 小时前
DVWA靶场通关——SQL Injection篇
数据库·sql
Yawesh_best19 小时前
告别系统壁垒!WSL+cpolar 让跨平台开发效率翻倍
运维·服务器·数据库·笔记·web安全
蒋士峰DBA修行之路19 小时前
实验二十八 SQL PATCH调优
数据库·sql·gaussdb
I***t71620 小时前
一条sql 在MySQL中是如何执行的
数据库·sql·mysql
一 乐20 小时前
应急知识学习|基于springboot+vue的应急知识学习系统(源码+数据库+文档)
数据库·vue.js·spring boot
微学AI21 小时前
内网穿透的应用-突破局域网束缚,MongoDB 远程访问使用cpolar原来可以这么简单
数据库·mongodb