问题描述
我需要在一个月的月末周(周二、周三、周四和周五)触发管道。
Monthend 定义为,
"Last but one" Friday
或
Second Friday from the end of the month
。
例如,对于 2021 年 6 月,18 日是月末(橙色,如图所示) Calendar Image
如果它只是在月末,即日历月末的第二个星期五,那很容易。只需在 Scheduled 触发器中使用 Occurrance 作为 -2 并将 day 作为 Friday 并添加到管道以触发,
"schedule": {
"monthlyOccurrences": [
{
"day": "Friday","occurrence": -2
}
]
}
但我还需要在同一周的周二、周三和周四跑步,我觉得这很困难,因为这些工作日可能是日历月末的第二个或第三个。例如:对于 2021 年 6 月,如图所示,我还需要在 15 日(日历月末的第三个星期二)、16 日(日历月末的第三个星期三)、17 日(月末的第二个星期四)运行日历月)。
您能否告诉我这是否可以使用 Azure 数据工厂的触发器来实现?如果没有,还有其他实施方式吗?谢谢!
解决方法
单独的预定触发器无法实现该逻辑(截至 2021 年 5 月 4 日)。最简单的解决方案是使用其他一些日程安排应用程序。
对于纯粹的数据工厂解决方案,将触发器安排在所有可能发生所需日期的日子。然后修改pipeline做逻辑判断当前日期是否真的是想要的日期之一。
Implementation details and sample code
逻辑:
- 找出当月的最后一天(下个月的第一天减去 1 天)。
- 减去一周,所以您处于倒数第二周
- 循环 [0,-1,-2,-3,-4,-5,-6] 作为添加到日期的天数。这会生成一周中每一天的日期。
- 使用 dayOfWeek 函数将日期更改为一周中的哪一天
- 过滤以获取星期五的日期
- 询问今天是否在星期五日期和星期五日期之间 - 3 天