迁移数据源

本指南介绍了如何将集成从 datafeedsdatafeedstatuses 服务迁移到 Merchant API 中的 Data sources 子 API。借助新的 Data sources 子 API,您可以更直接地控制数据流水线,并简化数据源管理。

如需详细了解新功能,请参阅管理数据 源指南。

主要区别

与 Content API for Shopping 相比,Merchant API 具有多项优势。

  • 明确创建数据源。API 不再在您首次插入商品时自动创建“Content API”数据源。在 Merchant API 中,您需要先明确创建数据源,然后才能向其中上传商品。 这样,您就可以从一开始更好地控制商品数据流水线的组织和管理。

  • 支持多个 API 数据源。在 Content API for Shopping 中,您只能使用一个自动创建的“Content API”数据源。借助 Merchant API,您可以创建和管理多个 API 输入类型的数据源。

  • 没有标签和语言的数据源。借助 Merchant API,您可以创建主数据源,而无需指定 feedLabelcontentLanguage。此类数据源接受以任意 feedLabelcontentLanguage 组合形式提供的商品,这简化了不需要为不同区域使用单独数据源的集成的商品上传流程。

  • 简化了数据目标。每个数据源现在都对应于一个目标,该目标由 feedLabelcontentLanguage 的唯一组合定义。Merchant API 中已弃用多数据目标 Feed。

  • 选择数据源策略。您可以通过三种方式管理数据源:

    1. 保留现有的 Content API 数据源。您可以继续使用通过 Content API for Shopping 创建的数据源,因为它们与 Merchant API 兼容。您可以使用 dataSources.list 或在 Merchant Center 界面中查找其资源名称。Content API 主数据源仅支持创建时使用的特定 feedLabelcontentLanguage。即使使用 Merchant API 插入商品,Content API 数据源也会在 Merchant Center 中显示“Content API”来源。您可以将它们与新的 Merchant API 数据源相结合,这些数据源也以特定的 feedLabelcontentLanguage 对为目标。

    2. 为每个标签和语言创建新的 Merchant API 数据源。 如果您需要支持新的 feedLabelcontentLanguage 组合(并且希望在它们之间保持严格分离),或者如果您使用依赖于特定 feedLabelcontentLanguage 的数据源规则设置,请使用此选项。您需要为使用的每对 feedLabelcontentLanguage 创建单独的数据源。

    3. 为任何标签和语言创建一个 Merchant API 数据源。 使用此选项可简化管理,因为您只需一个数据源即可接受具有任何 feedLabelcontentLanguage 的商品。 如果您选择此选项,我们建议您将所有商品迁移到此新数据源,并在商品迁移后移除旧的 Content API 数据源。

  • 专用的文件上传状态。Merchant API 使用单独的只读 fileUploads 资源来表示基于文件的数据源的状态。 如需检索文件上传的状态,请使用带有 latest 别名的 fileUploads.get 方法。

  • 新的数据源类型。DataSource 资源支持更多垂直行业,包括促销活动、本地商品目录和地区商品目录,从而提供一种统一的方式来管理所有数据流水线。

  • 自动化数据源。借助 Merchant API,您现在可以使用 Accounts 子 API 中的 autofeedSettings.updateAutofeedSettings 方法为 您的帐号启用或停用 自动化数据 源功能。如需了解详情,请参阅配置自动 Feed 设置

请求

下表比较了 Content API for Shopping 和 Merchant API 之间的请求网址格式。

请求说明 Content API for Shopping Merchant API
创建数据源 POST https://shoppingcontent.googleapis.com/content/v2.1/{MERCHANT_ID}/datafeeds POST https://merchantapi.googleapis.com/v1/accounts/{ACCOUNT_ID}/dataSources
获取数据源 GET https://shoppingcontent.googleapis.com/content/v2.1/{MERCHANT_ID}/datafeeds/{DATAFEED_ID} GET https://merchantapi.googleapis.com/v1/accounts/{ACCOUNT_ID}/dataSources/{DATASOURCE_ID}
列出数据源 GET https://shoppingcontent.googleapis.com/content/v2.1/{MERCHANT_ID}/datafeeds GET https://merchantapi.googleapis.com/v1/accounts/{ACCOUNT_ID}/dataSources
更新数据源 PUT https://shoppingcontent.googleapis.com/content/v2.1/{MERCHANT_ID}/datafeeds/{DATAFEED_ID} PATCH https://merchantapi.googleapis.com/v1/accounts/{ACCOUNT_ID}/dataSources/{DATASOURCE_ID}
删除数据源 DELETE https://shoppingcontent.googleapis.com/content/v2.1/{MERCHANT_ID}/datafeeds/{DATAFEED_ID} DELETE https://merchantapi.googleapis.com/v1/accounts/{ACCOUNT_ID}/dataSources/{DATASOURCE_ID}
提取数据源 POST https://shoppingcontent.googleapis.com/content/v2.1/{MERCHANT_ID}/datafeeds/{DATAFEED_ID}/fetchNow POST https://merchantapi.googleapis.com/v1/accounts/{ACCOUNT_ID}/dataSources/{DATASOURCE_ID}:fetch
获取数据源状态 GET https://shoppingcontent.googleapis.com/content/v2.1/{MERCHANT_ID}/datafeedstatuses/{DATAFEED_ID} GET https://merchantapi.googleapis.com/v1/accounts/{ACCOUNT_ID}/dataSources/{DATASOURCE_ID}/fileUploads/latest
列出数据源状态 GET https://shoppingcontent.googleapis.com/content/v2.1/{MERCHANT_ID}/datafeedstatuses 无法使用。请为每个基于文件的数据源使用 dataSources.listfileUploads.get

标识符

Merchant API 使用基于字符串的资源名称作为标识符。

标识符说明 Content API for Shopping Merchant API
数据源标识符 datafeedId(数字) name(字符串,格式:accounts/{account}/dataSources/{datasource}

方法

下表比较了 Content API for Shopping datafeedsdatafeedstatuses 服务中的方法及其在 Merchant API 中的等效方法。

Content API for Shopping 方法 Merchant API 方法 适用范围和备注
datafeeds.custombatch 无法使用 请改用单独的 API 调用。
datafeeds.delete dataSources.delete 可用。
datafeeds.fetchnow dataSources.fetch 可用。此方法现在仅适用于具有文件输入的数据源。
datafeeds.get dataSources.get 可用。
datafeeds.insert dataSources.create 可用。
datafeeds.list dataSources.list 可用。
datafeeds.update dataSources.update 可用。使用 PATCH 语义,而不是 PUT
datafeedstatuses.custombatch 无法使用 请改用单独的 API 调用。如需了解详情,请参阅一次发送多个请求
datafeedstatuses.get fileUploads.get 适用于基于文件的数据源。使用 latest 别名可获取最新上传的状态。对于其他数据源类型,状态信息是 DataSource 资源的一部分。
datafeedstatuses.list 无法使用 如需获取多个数据源的状态,请先使用 dataSources.list 列出所有数据源。然后,为每个基于文件的数据源使用带有 latest 别名的 fileUploads.get

详细字段更改

下表显示了 Content API for Shopping 中的 DatafeedDatafeedStatus 资源与 Merchant API 中的 DataSourceFileUpload 资源之间的字段级更改。

Content API for Shopping Merchant API 说明
Datafeed DataSource 用于数据源配置的主要资源。
id name 资源标识符。从数字 ID 更改为字符串资源名称。
name displayName 面向用户的数据源名称。
attributeLanguage primaryProductDataSource.contentLanguage 数据源中商品的双字母 ISO 639-1 语言代码。
fileName fileInput.fileName 上传文件的名称。此字段现在嵌套在 fileInput 下。
fetchSchedule fileInput.fetchSettings 提取基于文件的数据源的时间表。此字段现在嵌套在 fileInput 下。
fetchSchedule.paused fileInput.fetchSettings.enabled 逻辑已反转。paused: true 等效于 enabled: false
format 无法使用 移除了 fileEncodingcolumnDelimiterquotingMode 字段。这些字段现在会自动检测。
targets primaryProductDataSource.feedLabelprimaryProductDataSource.contentLanguageprimaryProductDataSource.countries 移除了重复的 targets 字段。每个数据源现在都有一个由这些字段定义的单个目标,这反映了多数据目标 Feed 的弃用。
DatafeedStatus FileUpload 文件上传的状态现在是一个单独的只读资源。
datafeedId name 文件上传的标识符,引用其父数据源。
processingStatus processingState 上传的处理状态。字符串值(successfailurein progress)替换为枚举(SUCCEEDEDFAILEDIN_PROGRESS)。
errorswarnings issues 错误和警告合并为一个 issues 列表。每个问题都有一个 severity 字段(ERRORWARNING)。
lastUploadDate uploadTime 上次上传的时间戳。格式从字符串更改为 Timestamp 对象。
countrylanguagefeedLabel 不适用 这些字段不再位于状态资源中。它们是 DataSource 资源的一部分。
targets[].included_destinationstargets[].excluded_destinations primaryProductDataSource.destinations 包含和禁止的目标平台这两个单独的列表替换为一个 destinations 列表。新列表中的每个项都是一个对象,用于指定目标及其状态(ENABLEDDISABLED),从而提供更明确的配置。