補助フィードを使用して商品データを部分的に更新するには、products.insert
、products.delete
、products.custombatch.insert
、products.custombatch.delete
の各メソッドを呼び出す際にクエリ パラメータとして feedId
を追加します。
たとえば、次の URL に対して products.insert
補助フィードのメソッド呼び出しを行うことができます。
POST https://shoppingcontent.googleapis.com/content/v2.1/merchantId/products?feedId=feedId
products.insert
補助フィードの products.insert
メソッドは、送信した商品フィールドをリクエスト本文に追加し、フィールドが存在する場合は上書きします。補助フィードを使用する場合、同じフィードの以前のリクエストにフィールドが含まれていた場合を除き、他のすべての商品フィールドは変更されません。他のフィードから追加されたデータは影響を受けませんが、同じフィードに対する以前のリクエストは、リクエストごとに上書きされます。つまり、補助フィード リクエストによってフィールドを追加または更新した後、そのフィールドを後続のリクエストに含めなかった場合、省略されたフィールドのデータはフィードから削除されます。この動作は、補助フィードを使用せずに products.insert
を呼び出す場合とは異なります。補助フィードを使用すると、既存の商品データがすべて削除され、リクエスト本文で送信するフィールドに置き換えられます。
次の URL を使用して、補助フィードの Product.insert
サービスにリクエストを送信します。
POST https://shoppingcontent.googleapis.com/content/v2.1/merchantId/products?feedId=feedId
リクエスト本文には、offerId
、feedLabel
、channel
、contentLanguage
フィールドを含める必要があります。それ以外のフィールドはすべて省略可能です。
例
商品の在庫状況を「在庫あり」から「在庫なし」に変更するには、次のリクエスト本文を使用して補助フィードの Product.insert
メソッド呼び出しを行います。
{
"offerId": "1111111111",
"contentLanguage": "en",
"feedLabel": "US",
"channel": "online",
"availability": "out of stock",
}
products.delete
products.delete
メソッドは、指定された補助フィードを使用して、以前に products.insert
呼び出しによって追加されたすべての補助データを削除します。補助フィードに対してこのメソッドを呼び出しても、補助フィードの Product.insert
呼び出しが行われる前に追加された元の商品データには影響しません。これは、特定のフィードのデータレイヤを削除するようなものです。他のフィードを介して追加されたデータは影響を受けず、補助フィードのレイヤが追加される前の状態に商品は実質的に元の状態に戻ります。これは、補助フィードなしで products.delete
を呼び出す場合と異なり、商品全体とそのすべてのデータが削除されます。
次の URL を使用して、補助フィードの products.delete
サービスをリクエストします。ここで、productId
は商品の REST ID で、channel:contentLanguage:feedLabel:offerId
として表されます。
DELETE https://shoppingcontent.googleapis.com/content/v2.1/merchantId/products/productId?feedId=feedId
補助フィードの products.delete
メソッド呼び出しにリクエスト本文は必要ありません。
products.custombatch
custombatch
メソッドを使用すると、1 回の API 呼び出しで複数の商品の補助フィードデータを insert
または delete
にすることで、API 呼び出しの回数を最小限に抑えることができます。
次のリクエスト URL を使用して custombatch
を呼び出します。
https://shoppingcontent.googleapis.com/content/v2.1/products/batch
すべての補助フィードの custombatch
呼び出しで、リクエスト本文に batchId
、merchantID
、method
、feedId
の各パラメータを含める必要があります。
products.custombatch:insert
products.custombatch:insert
メソッドに対して補助フィード呼び出しを行う場合は、必須の batchId
パラメータ、merchantID
パラメータ、method
パラメータに加えて、リクエスト本文に offerId
、feedLabel
、channel
、contentLanguage
を含める必要があります。その他の商品フィールドはすべて省略可能です。
例
既存の 2 つの商品の price
値を更新するには、次のリクエストを使用して products.custombatch:insert
メソッドを呼び出します。
{
"entries": [
{
"batchId": 1111,
"merchantId": 1234567,
"method": "insert",
"feedId": "7654321",
"product": {
"offerId": "1111111111",
"contentLanguage": "en",
"targetCountry": "US",
"feedLabel": "US",
"channel": "online",
"price": {
"value": "30.99",
"currency": "USD"
}
}
},
{
"batchId": 1112,
"merchantId": 1234567,
"method": "insert",
"feedId": "7654321",
"product": {
"offerId": "2222222222",
"contentLanguage": "en",
"targetCountry": "US",
"feedLabel": "US",
"channel": "online",
"price": {
"value": "33.99",
"currency": "USD"
},
},
}
}
products.custombatch:delete
指定した補助フィードを使用して 2 つの商品に加えられたすべての更新を削除するには、次のリクエストを使用して products.custombatch:delete
メソッド呼び出しを行います。
{
"entries": [
{
"batchId": 1115,
"merchantId": 1234567,
"method": "delete",
"feedId": "7654321",
"productId": "online:en:US:1111111111"
},
{
"batchId": 1116,
"merchantId": 1234567,
"method": "delete",
"feedId": "7654321",
"productId": "online:en:US:2222222222"
}
]
}