Azure SqlSink传递参数。

时间:2017-12-28 08:07:43

标签: azure stored-procedures azure-data-factory

在Azure数据工厂管道中,我试图将参数传递给Azure SQL中的存储过程(下面的步骤2)。但我找不到怎么样。有些人知道如何将参数列表(从输入数据集)传递到存储过程(outputdataset)并让存储过程完成工作吗?(在这种情况下,upsert)

规范

1.Input数据集从blob存储中获取json(它的列表)。  2. Pipeline使用步骤1中的参数调用存储过程。

管道

{
    "name": "SprocActivitySamplePipeline",
    "properties": {
        "activities": [
            {
                "type": "SqlServerStoredProcedure",
                "typeProperties": {
                    "storedProcedureName": "UpsesrtSensorRecords",
                    "storedProcedureParameters": {
                        "device_id": "*device_id from input dataset",
                        "user_id": "1",
                        "serial": "serial from input dataset",
                        "measured_time": "$$Text.Format('{0:yyyy-MM-dd HH:mm:ss}', SliceStart)"
                    }
                },
                "sink" : {
                    "type": "SqlSink"
                },
                "inputs": [
                    {
                        "name": "SimpleCopyInputDataset"
                    }
                ],
                "outputs": [
                    {
                        "name": "AzureSQLSprocOut"
                    }
                ],
                "scheduler": {
                    "frequency": "Day",
                    "interval": 1
                },
                "name": "SprocActivitySample"
            }
        ],
        "start": "2017-04-04T00:00:00Z",
        "end": "2017-04-04T05:00:00Z",
        "isPaused": false,
        "hubName": "yoshinobufuruyadf_hub",
        "pipelineMode": "Scheduled"
    }
}

输入数据集

{
    "name": "SimpleCopyInputDataset",
    "properties": {
        "structure": [
            {
                "name": "device_id",
                "type": "String"
            },
            {
                "name": "user_id",
                "type": "Int64"
            },
            {
                "name": "serial",
                "type": "String"
            },
            {
                "name": "longitude",
                "type": "Double"
            },
            {
                "name": "latitude",
                "type": "Double"
            },
            {
                "name": "location_name",
                "type": "String"
            },
            {
                "name": "measured_time",
                "type": "String"
            },
            {
                "name": "water_level",
                "type": "Double"
            },
            {
                "name": "water_temperature",
                "type": "Double"
            },
            {
                "name": "temperature",
                "type": "Double"
            },
            {
                "name": "relative_temperature",
                "type": "Double"
            },
            {
                "name": "soil_temperature",
                "type": "Double"
            },
            {
                "name": "soil_moisture",
                "type": "Double"
            },
            {
                "name": "soil_ec",
                "type": "Double"
            },
            {
                "name": "water_ec",
                "type": "Double"
            },
            {
                "name": "leaf_wetting",
                "type": "Double"
            },
            {
                "name": "soil_temperature_5cm",
                "type": "Double"
            },
            {
                "name": "soil_temperature_10cm",
                "type": "Double"
            },
            {
                "name": "external_solar_radiation",
                "type": "Double"
            },
            {
                "name": "salt_concentration",
                "type": "Double"
            },
            {
                "name": "weather_wind_direction",
                "type": "Double"
            },
            {
                "name": "weather_wind_speed",
                "type": "Double"
            },
            {
                "name": "weather_instant_wind_speed",
                "type": "Double"
            },
            {
                "name": "weather_rainfall",
                "type": "Double"
            },
            {
                "name": "weather_temperature",
                "type": "Double"
            },
            {
                "name": "weather_relative_temperature",
                "type": "Double"
            },
            {
                "name": "weather_ultraviolet_ray_amount",
                "type": "Double"
            },
            {
                "name": "weather_illuminance",
                "type": "Int64"
            }
        ],
        "published": false,
        "type": "AzureBlob",
        "linkedServiceName": "AzureStorageLinkedService",
        "typeProperties": {
            "fileName": "NormalizedData.json",
            "folderPath": "imported-json",
            "format": {
                "type": "JsonFormat",
                "jsonNodeReference": "$.['sensors']",
                "jsonPathDefinition": {
                    "device_id": "['device_id']",
                    "user_id": "['user_id']",
                    "serial": "['serial']",
                    "longitude": "['longitude']",
                    "latitude": "['latitude']",
                    "location_name": "['location_name']",
                    "measured_time": "['measured_time']",
                    "water_level": "['water_level']",
                    "water_temperature": "['water_temperature']",
                    "temperature": "['temperature']",
                    "relative_temperature": "['relative_temperature']",
                    "soil_temperature": "['soil_temperature']",
                    "soil_moisture": "['soil_moisture']",
                    "soil_ec": "['soil_ec']",
                    "water_ec": "['water_ec']",
                    "leaf_wetting": "['leaf_wetting']",
                    "soil_temperature_5cm": "['soil_temperature_5cm']",
                    "soil_temperature_10cm": "['soil_temperature_10cm']",
                    "external_solar_radiation": "['external_solar_radiation']",
                    "salt_concentration": "['salt_concentration']",
                    "weather_wind_direction": "['weather_wind_direction']",
                    "weather_wind_speed": "['weather_wind_speed']",
                    "weather_instant_wind_speed": "['weather_instant_wind_speed']",
                    "weather_rainfall": "['weather_rainfall']",
                    "weather_temperature": "['weather_temperature']",
                    "weather_relative_temperature": "['weather_relative_temperature']",
                    "weather_ultraviolet_ray_amount": "['weather_ultraviolet_ray_amount']",
                    "weather_illuminance": "['weather_illuminance']"
                }
            }
        },
        "availability": {
            "frequency": "Day",
            "interval": 1
        },
        "external": true,
        "policy": {}
    }
}

存储过程

Create  PROCEDURE UpsesrtSensorRecords 
(
@device_id INT,
@user_id INT,
@serial VARCHAR(16),
@longitude  FLOAT = NULL,
@latitude FLOAT = NULL,
@location_name VARCHAR(128) = NULL,
@measured_time DATETIME,
@water_level FLOAT = NULL,
@water_temperature FLOAT = NULL,
@temperature FLOAT = NULL,
@relative_temperature FLOAT = NULL,
@soil_temperature FLOAT = NULL,
@soil_moisture FLOAT = NULL,
@soil_ec FLOAT = NULL,
@water_ec FLOAT = NULL,
@leaf_wetting FLOAT = NULL,
@soil_temperature_5cm FLOAT = NULL,
@soil_temperature_10cm FLOAT = NULL,
@external_solar_radiation FLOAT = NULL,
@salt_concentration FLOAT = NULL,
@weather_wind_direction FLOAT = NULL,
@weather_wind_speed FLOAT = NULL,
@weather_instant_wind_speed FLOAT = NULL,
@weather_rainfall FLOAT = NULL,
@weather_temperature FLOAT = NULL,
@weather_relative_temperature FLOAT = NULL,
@weather_ultraviolet_ray_amount FLOAT = NULL,
@weather_illuminance INT = NULL
)

AS
DECLARE @RowCount INT;
BEGIN
    SET @RowCount = (SELECT count(*) FROM dbo.T_SensorRecords WHERE (device_id = @device_id)AND (measured_time = @measured_time));

    IF @RowCount=0  
          INSERT INTO dbo.T_SensorRecords (device_id,user_id,serial,longitude,latitude,location_name,measured_time,water_level ,water_temperature ,temperature ,relative_temperature ,soil_temperature ,soil_moisture ,soil_ec ,water_ec ,leaf_wetting ,soil_temperature_5cm ,soil_temperature_10cm ,external_solar_radiation ,salt_concentration ,weather_wind_direction ,weather_wind_speed ,weather_instant_wind_speed ,weather_rainfall,weather_temperature ,weather_relative_temperature,weather_ultraviolet_ray_amount,weather_illuminance )
          VALUES(@device_id,@user_id,@serial,@longitude,@latitude,@location_name,@measured_time,@water_level ,@water_temperature ,@temperature ,@relative_temperature ,@soil_temperature ,@soil_moisture ,@soil_ec ,@water_ec ,@leaf_wetting ,@soil_temperature_5cm ,@soil_temperature_10cm ,@external_solar_radiation ,@salt_concentration ,@weather_wind_direction ,@weather_wind_speed ,@weather_instant_wind_speed ,@weather_rainfall,@weather_temperature ,@weather_relative_temperature,@weather_ultraviolet_ray_amount,@weather_illuminance);
    ELSE
        UPDATE dbo.T_SensorRecordss
        SET user_id=@user_id,serial=@serial,longitude=@longitude,latitude=@latitude,location_name=@location_name,water_level=@water_level,water_temperature=@water_temperature,temperature=@temperature,relative_temperature=@relative_temperature,soil_temperature=@soil_temperature,soil_moisture=@soil_moisture,soil_ec=@soil_ec,water_ec=@water_ec,leaf_wetting=@leaf_wetting,soil_temperature_5cm=@soil_temperature_5cm,soil_temperature_10cm=@soil_temperature_10cm,external_solar_radiation=@external_solar_radiation,salt_concentration=@salt_concentration,weather_wind_direction=@weather_wind_direction,weather_wind_speed=@weather_wind_speed,weather_instant_wind_speed=@weather_instant_wind_speed,weather_rainfall=@weather_rainfall,weather_temperature=@weather_temperature,weather_relative_temperature=@weather_relative_temperature,weather_ultraviolet_ray_amount=@weather_ultraviolet_ray_amount,weather_illuminance=@weather_illuminance
        WHERE device_id = @device_id AND measured_time = @measured_time;
END

我发现以前的帖子没有回答非常相似。 Azure data factory SqlSink, use json as input。他似乎没有得到答案。

1 个答案:

答案 0 :(得分:0)

您需要使用元数据和查找活动对ADFv2执行此操作。然后让存储的proc调用活动依赖于上游结果。

我无法真正评论,因为我实际上没有做过,但知道它可能。

希望这有帮助。