Azure数据工厂数据复制源中的查找活动-语法错误

时间:2019-05-30 10:18:16

标签: azure azure-data-factory-2

完成此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"
        }
    ]
}

1 个答案:

答案 0 :(得分:0)

这看起来像是语法问题,请尝试下面的复制活动查询:

@{CONCAT('select * from Shipment where CreatedOn > ', activity('GetCurrentWatermarkValue').output.firstRow.CurrentWatermarkValue, ' and CreatedOn <= ', activity('GetNewWatermarkValue').output.firstRow.NewWatermarkValue}

除非您要手动设置映射,否则不要使用映射,如果列名相同,则只需单击“清除”。

希望这对您有帮助!