如何解决在月末的第二个周五以及同一周的周二、周三和周四触发 Azure 数据工厂管道
我需要在一个月的月末周(周二、周三、周四和周五)触发管道。
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 天
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。