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

在月末的第二个周五以及同一周的周二、周三和周四触发 Azure 数据工厂管道

如何解决在月末的第二个周五以及同一周的周二、周三和周四触发 Azure 数据工厂管道

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

Monthend 定义为, "Last but one" FridaySecond 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. 找出当月的最后一天(下个月的第一天减去 1 天)。
  2. 减去一周,所以您处于倒数第二周
  3. 循环 [0,-1,-2,-3,-4,-5,-6] 作为添加到日期的天数。这会生成一周中每一天的日期。
  4. 使用 dayOfWeek 函数将日期更改为一周中的哪一天
  5. 过滤以获取星期五的日期
  6. 询问今天是否在星期五日期和星期五日期之间 - 3 天

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