1

我需要一个管道在一个月的周末(周二、周三、周四和周五)触发。

Monthend 定义为, "Last but one" FridaySecond Friday from the end of the month

例如,对于 2021 年 6 月,18 日是 Monthend(如图所示的橙色) Calendar Image

如果它只是在月末,即日历月末的第二个星期五,那很容易。只需在 Scheduled trigger 中使用 Occurrance 作为 -2 和 day 作为 Friday 并添加到管道以触发,

"schedule": {
                    "monthlyOccurrences": [
                        {
                            "day": "Friday",
                            "occurrence": -2
                        }
                    ]
                }

但我还需要在同一周的周二、周三和周四跑步,我觉得这很困难,因为这些工作日可能是日历月末的第二个或第三个工作日。例如:对于 2021 年 6 月,如图所示,我还需要在 15 日(日历月末的第三个星期二)、16 日(日历月末的第三个星期三)、17 日(日历月末的第二个星期四)运行日历月)。

您能否告诉我这是否可以使用 Azure 数据工厂的触发器来实现?如果没有,还有其他实现方式吗?谢谢你!

4

1 回答 1

1

仅计划的触发器无法实现该逻辑(截至 2021-05-04)。最简单的解决方案是使用其他一些调度应用程序。

对于纯粹的数据工厂解决方案,将触发器安排在可能发生所需日期的所有日期。然后修改流水线做逻辑来判断当天是否真的是想要的日子之一。

实现细节和示例代码

逻辑:

  1. 查找该月的最后一天(下个月的第一天减去 1 天)。
  2. 减去一周,所以你在倒数第二周
  3. 循环 [0,-1,-2,-3,-4,-5,-6] 作为要添加到日期的天数。这会产生一周中每一天的日期。
  4. 使用 dayOfWeek 函数将日期更改为星期几
  5. 过滤以获取星期五日期
  6. 询问今天是否在星期五日期和星期五日期之间 - 3 天
于 2021-05-04T19:58:16.210 回答