0

假设我们有以下输入参数:

  • 日期 [日期]
  • 期间[整数]

任务如下:构建具有两列的表:datedayname

所以,如果我们有date=2018-07-12period=3表应该是这样的:

date      |dayname 
-------------------
2018-07-12|THURSDAY
2018-07-13|FRIDAY
2018-07-14|SATURDAY

我的解决方案如下:

 select add_days(date, -1) into previousDay from "DUMMY";
 for i in 1..:period do
     select add_days(previousDay, i) into nextDay from "DUMMY";
     :result.insert((nextDay, dayname(nextDay));
 end for;

但我不喜欢循环。我假设如果我想将更复杂的值放入结果表中,则性能可能会出现问题。

实现目标的更好解决方案是什么?

4

2 回答 2

1

运行一个循环并一个一个地插入值肯定是完成任务的最慢的选择。

相反,您可以使用 SAP HANA 的时间序列功能。像这样的声明

SELECT to_date(GENERATED_PERIOD_START)
    FROM SERIES_GENERATE_TIMESTAMP('INTERVAL 1 DAY', '01.01.0001', '31.12.9999')

您可以生成具有给定间隔长度的有效日期范围。

在我使用这种方法的测试中,有时间插入一组来自 ca 的日期。9分钟到7秒...

如果你想要更多的例子,我前段时间在这里这里写过。在这些示例中,我什至使用了允许有效压缩时间戳列值的系列表。

于 2018-07-14T11:18:01.677 回答
0

系列数据函数包括SERIES_GENERATE_DATE,它以日期数据格式返回一组值。因此,您不必费心将返回的数据转换为所需的日期格式。

这是一个示例代码

declare d int := 5;
declare dstart date := '01.01.2018';

SELECT generated_period_start FROM SERIES_GENERATE_DATE('INTERVAL 1 DAY', :dstart, add_days(:dstart, :d));
于 2018-09-06T05:33:37.563 回答