完成此https://docs.microsoft.com/en-us/azure/data-factory/tutorial-incremental-copy-portal
我有一个使用sqlReaderQuery的名为GetCurrentWatermarkValue的查找活动:
Select WaterMarkValue as CurrentWatermarkValue\nfrom WatermarkTable
我还有一个名为sqlReaderQuery的活动,名为GetNewWatermarkValue:
select max(createdon) as NewWatermarkValue from shipment
然后我尝试使用
在源代码中将它们都用于数据复制活动select *
from Shipment
where CreatedOn > '@{activity('GetCurrentWatermarkValue').output.firstRow.CurrentWatermarkValue}'
and CreatedOn <= '@{activity('GetNewWatermarkValue').output.firstRow.NewWatermarkValue}'
“预览数据”按钮呈灰色(但是当我删除where条件时启用),因此明显存在错误
设置好接收器后,我尝试设置“映射”。单击“映射”选项卡上的“导入模式”,将提供:
A database operation failed with the following error: 'Incorrect syntax near 'GetCurrentWatermarkValue'.'. Activity ID:98794aa9-c866-48d6-b9ff-9cb277bac6ed
我想也许我应该使用添加动态内容选项,但这只是给出了
Query is required
我在某处读到,当在Lookup活动中设置“仅第一行”时,firstRow之后的文本。应该是[TableName],但这似乎不正确。
查找:
{
"name": "GetCurrentWatermarkValue",
"type": "Lookup",
"policy": ...,
"typeProperties": {
"source": {
"type": "AzureSqlSource",
"sqlReaderQuery": "Select WaterMarkValue as CurrentWatermarkValue\nfrom WatermarkTable"
},
"dataset": {
"referenceName": "WatermarkTable",
"type": "DatasetReference"
}
}
}
查找:
{
"name": "GetNewWatermarkValue",
"type": "Lookup",
"policy": ...,
"typeProperties": {
"source": {
"type": "AzureSqlSource",
"sqlReaderQuery": "select max(createdon) as NewWatermarkValue from shipment"
},
"dataset": {
"referenceName": "ShipmentsTable",
"type": "DatasetReference"
}
}
}
数据复制:
{
"name": "ArchiveShipments",
"type": "Copy",
"dependsOn": [
{
"activity": "GetCurrentWatermarkValue",
"dependencyConditions": [
"Succeeded"
]
},
{
"activity": "GetNewWatermarkValue",
"dependencyConditions": [
"Succeeded"
]
}
],
"policy": ...,
"typeProperties": {
"source": {
"type": "AzureSqlSource",
"sqlReaderQuery": {
"value": "select *\nfrom Shipment\nwhere CreatedOn > '@{activity('GetCurrentWatermarkValue').output.firstRow.CurrentWatermarkValue}' \nand CreatedOn <= '@{activity('GetNewWatermarkValue').output.firstRow.NewWatermarkValue}'",
"type": "Expression"
}
},
"sink": {
"type": "AzureSqlSink"
},
"enableStaging": false
},
"inputs": [
{
"referenceName": "ShipmentsTable",
"type": "DatasetReference"
}
],
"outputs": [
{
"referenceName": "ShipmentArchiveTable",
"type": "DatasetReference"
}
]
}
答案 0 :(得分:0)
这看起来像是语法问题,请尝试下面的复制活动查询:
@{CONCAT('select * from Shipment where CreatedOn > ', activity('GetCurrentWatermarkValue').output.firstRow.CurrentWatermarkValue, ' and CreatedOn <= ', activity('GetNewWatermarkValue').output.firstRow.NewWatermarkValue}
除非您要手动设置映射,否则不要使用映射,如果列名相同,则只需单击“清除”。
希望这对您有帮助!