主要术语
- 资源
- Google Ads 中的实体,例如
campaign或ad_group。 - Segment
- 用于对数据进行分组的维度,例如
segments.date或segments.device。 如果SELECT子句中包含细分,并且还包含指标,则指标会按细分进行拆分。 - 指标
- 一种效果衡量指标,例如
metrics.impressions或metrics.clicks。 - 归因资源
- 一种隐式联接到
FROM子句中的主要资源的资源,可让您选择其属性以及主要资源属性。
查询资源或元数据信息
Google Ads 查询语言可查询以下类型的信息的 Google Ads API:
使用
GoogleAdsServiceSearch 或 SearchStream 的资源及其相关属性、细分和指标:GoogleAdsService 查询的结果是一个GoogleAdsRow实例列表,其中每个GoogleAdsRow代表一个资源。如果请求了任何属性或指标,则相应行也会包含这些字段。如果请求了任何细分,则响应还会针对每个细分资源元组显示一个额外的行。
有关
GoogleAdsFieldService中可用字段和资源的元数据:此服务提供可查询字段的目录,其中包含有关其兼容性和类型的详细信息。GoogleAdsFieldService查询的结果是一个GoogleAdsField实例列表,其中每个GoogleAdsField都包含有关所请求字段的详细信息。
如需详细了解查询结构,请参阅查询结构和 Google Ads 查询语言语法。
查询资源属性
以下是针对广告系列资源属性的基本查询示例,展示了如何返回广告系列 ID、名称和状态:
SELECT
campaign.id,
campaign.name,
campaign.status
FROM campaign
ORDER BY campaign.id
此查询按广告系列 ID 排序。每个生成的 GoogleAdsRow 都表示一个填充了所选字段(包括广告系列的 resource_name)的 campaign 对象。
如需了解还有哪些其他字段可用于广告系列查询,请参阅 Campaign 参考文档。
查询指标
除了为给定资源选择属性之外,您还可以查询相关指标:
SELECT
campaign.id,
campaign.name,
campaign.status,
metrics.impressions
FROM campaign
WHERE campaign.status = 'PAUSED'
AND metrics.impressions > 1000
ORDER BY campaign.id
此查询仅过滤出状态为 PAUSED 且按广告系列 ID 排序时展示次数超过 1000 次的广告系列。每个生成的 GoogleAdsRow 都包含一个填充了所选指标的 metrics 字段。
如需查看可查询指标的列表,请参阅 Metrics 文档。
查询细分
除了给定资源所选的属性之外,您还可以查询相关细分:
SELECT
campaign.id,
campaign.name,
campaign.status,
metrics.impressions,
segments.date,
FROM campaign
WHERE campaign.status = 'PAUSED'
AND metrics.impressions > 1000
AND segments.date during LAST_30_DAYS
ORDER BY campaign.id
与查询指标类似,此查询仅过滤出状态为 PAUSED 且展示次数超过 1000 次的广告系列。不过,此查询会按日期细分数据。这样一来,每个生成的 GoogleAdsRow 都表示一个元组,其中包含广告系列和日期 Segment。细分会拆分所选指标,并按 SELECT 子句中的每个细分进行分组。
如需查看可查询的细分,请参阅 Segments 文档。
查询相关资源的属性
在针对给定资源的查询中,您可以与其他相关资源进行联接(如果可用)。这些相关资源称为“归因资源”。您可以在查询中选择一个属性,以针对归因资源进行隐式联接。
SELECT
campaign.id,
campaign.name,
campaign.status,
bidding_strategy.name
FROM campaign
ORDER BY campaign.id
此查询不仅会选择广告系列属性,还会从所选的每个广告系列中提取相关属性。每个生成的 GoogleAdsRow 都表示一个 campaign 对象,其中填充了所选的广告系列属性以及所选的出价策略属性 bidding_strategy.name。
如需了解哪些归因资源可用于广告系列查询,请参阅 Campaign 参考文档。
最佳做法
- 仅选择所需的字段,以避免响应时间过长和超时。
- 在开发和测试期间使用
LIMIT,以避免处理大型结果集。 - 在
WHERE子句中应用过滤条件,以最大限度地减少数据传输和响应大小。 - 在构建复杂查询之前,使用
GoogleAdsFieldService检查字段兼容性和数据类型。 - 请注意,某些字段(尤其是涉及大量数据或复杂计算的字段)可能会增加查询费用。
根据查询结果进行变异
查询给定资源时,您可以立即将返回的结果作为对象获取,修改这些对象,然后将其发回给相应资源服务中的 mutate 方法。以下是一个示例工作流程:
1. 执行查询,查找当前处于 PAUSED 状态且展示次数超过 1000 的所有广告系列。
1. 从响应中每个 GoogleAdsRow 的 campaign 字段获取 Campaign 对象。
1. 将每个广告系列的状态从 PAUSED 更改为 ENABLED。
1. 使用修改后的广告系列调用 CampaignService.MutateCampaigns 以更新广告系列。
字段元数据
发送到 GoogleAdsFieldService 的查询用于检索字段元数据。此信息可用于了解如何在查询中一起使用这些字段。由于数据可从 API 获取,并且该 API 提供验证或构建查询所需的必要元数据,因此开发者可以以编程方式执行此操作。以下是典型的元数据查询:
SELECT
name,
category,
selectable,
filterable,
sortable,
selectable_with,
data_type,
is_repeated
WHERE name = "<INSERT_RESOURCE_OR_FIELD>"
您可以在此查询中将 <INSERT_RESOURCE_OR_FIELD> 替换为资源(例如 customer 或 campaign)或字段(例如 campaign.id、metrics.impressions 或 ad_group.id)。
如需查看可查询字段的列表,请参阅 GoogleAdsField 文档。
代码示例
客户端库提供了有关如何在 GoogleAdsService 中使用 Google Ads 查询语言的示例。基本操作文件夹中也包含了各种示例,例如 GetCampaigns、GetKeywords 和 SearchForGoogleAdsFields。