微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

有没有办法访问 SQL 中以前的特定值?

如何解决有没有办法访问 SQL 中以前的特定值?

我在 Oracle live sql 中使用同一张表处理全年的数据(其中的间隔可以更大)。

这只是一个例子(整个表格的一部分):

Example table

我必须添加两列来显示日期所在的间隔(基于最小值、间隔和最大值)。

发件人列: 如果日期在 Oddo 列中标记为 min 或两者,则应仅显示该日期,如果标记为 between 或 max,则应显示一个最小日期。

到列: 如果日期在 Oddo 列中被标记为 max 或两者,它应该只显示该日期,如果它被标记为 between 或 min 它应该显示一个最大日期。 最终结果应如下所示:

Final result

非常感谢您的任何建议。

解决方法

在 Oracle 中,一种方法是条件累积聚合:

select t.*,max(case when odd = 'min' then date end) over (order by date) as min_date,min(case when odd = 'max' then date end) over (order by date desc) as max_date
from t;

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。