概要
Azure Data Factory (ADF)にて ADF 標準の Salesforce コネクターでなく Salesforce REST API によるコピーアクティビティを実施した際に発生する下記のような Deserialization failed エラーへの対応方法を共有します。Create a Record
を実施する際に渡す json が配列ではなく、単一のオブジェクトとして渡す必要があります。コピーアクティビティでは配列で渡されているような動作をしているため、単一のオブジェクトとして渡すように修正する必要があります。
[{"message":"Json Deserialization failed on token 'null' and has left off in the middle of parsing a row. Will go to end of row to begin parsing the next row","errorCode":"INVALID_FIELD"}]
データを追加する REST API のドキュメントにて、下記のように単一のオブジェクトを渡すことが記述されています。
引用元:Create a Record | REST API Developer Guide | Salesforce Developers
本記事ではエラーとなったパイプライン、配列の json を渡した際に同様のエラーが発生するパイプラインにおける実行結果とその対応方法を共有します。
エラーの再現方法
Salesforce REST API によりシンクするパイプラインを実行
アクセストークンを取得後に REST API によるシンクのコピーアクティビティを実行すると下記のようなエラーが発生しました。
Failure happened on 'Sink' side. ErrorCode=RestCallFailedWithClientError,'Type=Microsoft.DataTransfer.Common.Shared.HybridDeliveryException,Message=Rest call failed with client error, status code 400 BadRequest, please check your activity settings.
Request URL: https://{salesforceDomainName}.my.salesforce.com/services/data/v61.0/sobjects/Account.
Response: [{"message":"Json Deserialization failed on token 'null' and has left off in the middle of parsing a row. Will go to end of row to begin parsing the next row","errorCode":"INVALID_FIELD"}],Source=Microsoft.DataTransfer.ClientLibrary,'
配列の json を渡す web アクティビティのパイプラインを実行
下記のような配列の json を渡す web アクティビティのパイプラインを実行すると、同様のエラーが発生しました。
[
{
"Name": "abc"
}
]
[{"message":"Json Deserialization failed on token 'null' and has left off in the middle of parsing a row. Will go to end of row to begin parsing the next row","errorCode":"INVALID_FIELD"}]
対応方法
lookup アクティビティにて取得した json の値をループにより REST API を実行
lookup アクティビティにてソースから json 形式で値を取得後、ForEach アクティビティにてその値をループ処理に単一のオブジェクトとして web アクティビティにて Salesforce REST API を実行するようにします。
上記のパイプラインを実行後、Salesforce にて想定通りにデータが書きこまれていることを確認できました。