大多数资源都是使用 Mutate
方法进行修改(创建、更新或移除)的。Mutate
方法作为 HTTP POST
调用到与资源名称格式匹配的特定于资源的网址,但不包含尾随的资源 ID。要更改的资源的 ID 会改为在 JSON 请求正文中发送。这样,您就可以发送包含针对不同资源的多个操作的单个 API 调用。
例如,广告系列的资源名称采用以下格式:
customers/CUSTOMER_ID/campaigns/CAMPAIGN_ID
如需派生用于更改广告系列的网址,请省略末尾的资源 ID 并附加 :mutate
:
https://googleads.googleapis.com/v20/customers/CUSTOMER_ID/campaigns:mutate
Mutate
消息包含一个顶级 JSON 对象,该对象具有一个 operations
数组,该数组可以包含多个 operation
对象。每个操作依次可以是:create
、update
或 remove
。这些是唯一可能的 mutate 操作。
POST /v20/customers/CUSTOMER_ID/campaigns:mutate HTTP/1.1 Host: googleads.googleapis.com Content-Type: application/json Authorization: Bearer ACCESS_TOKEN developer-token: DEVELOPER_TOKEN { "operations": [ ... ] }
大多数服务都支持在单个 API 调用中执行数千项操作。系统限制指南记录了请求大小的限制。
默认情况下,单个 API 请求中的操作会作为一组操作来执行,这意味着如果任何单个操作失败,则所有操作都会一起失败。某些服务支持 partialFailure
属性来更改此行为。如需详细了解 mutate 操作语义,请参阅更改资源。
创建
创建操作会生成新实体,并且必须包含您打算创建的资源的完整 JSON 表示法。
POST /v20/customers/CUSTOMER_ID/campaigns:mutate HTTP/1.1 Host: googleads.googleapis.com Content-Type: application/json Authorization: Bearer ACCESS_TOKEN developer-token: DEVELOPER_TOKEN { "operations": [ { "create": { "name": "An example campaign", "status": "PAUSED", "campaignBudget": "customers/CUSTOMER_ID/campaignBudgets/CAMPAIGN_BUDGET_ID", "advertisingChannelType": "SEARCH", "networkSettings": { "targetGoogleSearch": true, "targetSearchNetwork": true, "targetContentNetwork": true, "targetPartnerSearchNetwork": false }, "target_spend": {} } } ] }
更新
更新操作会对现有资源执行稀疏更新。您只需指定要修改的字段。
如需指定要更新的字段,请将 updateMask
属性设置为以英文逗号分隔的字段名称列表。如果您已经拥有对象的完整 JSON 表示形式(例如,由之前的 API 调用返回),但只想更改某些字段,此方法就特别有用。您无需剪除 JSON 对象,只需在 updateMask
中列出要修改的字段名称,然后发送整个 JSON 对象即可。
以下示例更改了具有指定 resourceName
的现有广告系列的 name
和 status
。
POST /v20/customers/CUSTOMER_ID/campaigns:mutate HTTP/1.1 Host: googleads.googleapis.com Content-Type: application/json Authorization: Bearer ACCESS_TOKEN developer-token: DEVELOPER_TOKEN { "operations": [ { "updateMask": "name,status", "update": { "resourceName": "customers/CUSTOMER_ID/campaigns/CAMPAIGN_ID", "name": "My renamed campaign", "status": "PAUSED", } } ] }
移除
移除操作会有效地删除对象,并将其 Google Ads 状态设置为 REMOVED
。只需提供要移除的 resourceName
。
POST /v20/customers/CUSTOMER_ID/campaigns:mutate HTTP/1.1 Host: googleads.googleapis.com Content-Type: application/json Authorization: Bearer ACCESS_TOKEN developer-token: DEVELOPER_TOKEN { "operations": [ { "remove": "customers/CUSTOMER_ID/campaigns/CAMPAIGN_ID" } ] }