oracle 时间累积合并计算

针对多条不连续或重叠的时间段,博客讨论了在Oracle数据库中如何进行时间累积合并计算。通过递归查询和SPL脚本,解决时间段合并问题,特别是处理时间段内含的情况。提供了多种实现方式,包括按时间排序、分组、构建新序表,并展示如何在Java应用中调用SPL脚本。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

【问题】

       请教一个问题:
如果我通过sql查询能检索出来多条时间段,我怎么快速计算出来时间。
举例:
我的检索结果:
  2014-9-1 10:00  2014-9-2 11:30
  2014-9-1 10:30  2014-9-2 11:00
  2014-9-3  11:00  2014-9-4 12:00
由于第二段时间包含在第一段时间之内,所以程序要检测出来,同时只用第一段时间的和+第三段时间的和(第三段时间是独立的)]

【回答】

       Oracle下可以借助递归查询(connect by)语句,但由于集合无序,这个语句还是挺难想明白的,而且需求再复杂些就更难写了(比如把重复时间段聚合等)。这种数据量不大的情况下,SPL要灵活简单一些,下面给出几种实现写法:

A
1 $select * from SHIP_BERTH order by S
2 =A1.group@i(S>max(E[,-1]))
3 =A2.new(~.min(S): S,~.max(E): E)
4 =A3.sum(interval@s(S,E))
5 =A1.selec
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值