[英]Azure Data Factory V2 logical OR
我们可以。
您可以添加If 条件来创建逻辑管道。 如果两个副本活动 output 状态包含“失败”,则调用 API。
正如我们所知,每个激活的副本都有 output 具有以下详细信息:
"executionDetails": [
{
"source": {
"type": "AzureSqlDatabase",
"region": "East US"
},
"sink": {
"type": "AzureSqlDatabase",
"region": "East US"
},
"status": "Succeeded",
"start": "2020-07-08T05:37:33.9079553Z",
"duration": 4,
"usedDataIntegrationUnits": 4,
"usedParallelCopies": 1,
"profile": {
"queue": {
"status": "Completed",
"duration": 2
},
"transfer": {
"status": "Completed",
"duration": 1,
"details": {
"readingFromSource": {
"type": "AzureSqlDatabase",
"workingDuration": 0,
"timeToFirstByte": 0
},
"writingToSink": {
"type": "AzureSqlDatabase",
"workingDuration": 0
}
}
}
},
我们可以将executionDetails:{"status": "Succeeded"}
设置为 if 条件激活:
表达式:无论哪个活动失败,所有 API:
@or(equals(activity('Copy data1').output.executionDetails.status,'Failed'),equals(activity('Copy data2').output.executionDetails.status,'Failed') )
如果所有复制活动都“成功”(条件为假)并且我们不想做任何事情,我们不需要添加假活动。
希望这可以帮助。
不是我知道的。 当一个活动有多个条件时,它们被视为 AND 条件,这意味着两个复制活动都必须无法执行 web 活动。
执行此操作的一种常见模式是创建一个封装逻辑以报告错误的管道,并从每个活动的失败中调用它,将错误 output 捕获到管道参数。
希望这有帮助!
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.