Google Ads 查询语言

查询资源或元数据信息

Google Ads 查询语言可查询以下类型的信息的 Google Ads API:

  • 使用 GoogleAdsService SearchSearchStream 的资源及其相关属性、细分和指标:GoogleAdsService 查询的结果是一个 GoogleAdsRow 实例列表,其中每个 GoogleAdsRow 都表示一个资源。

    如果请求了任何属性或指标,则相应行也会包含这些字段。如果请求了任何细分,则响应还会针对每个细分资源元组显示一个额外的行。

  • 有关 GoogleAdsFieldService 中可用字段和资源的元数据:此服务提供可查询字段的目录,其中包含有关其兼容性和类型的详细信息。

    GoogleAdsFieldService 查询的结果是一个 GoogleAdsField 实例列表,其中每个 GoogleAdsField 都包含有关所请求字段的详细信息。

查询资源属性

以下示例展示了如何针对广告系列资源的属性执行基本查询,以返回广告系列 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 参考文档

根据查询结果进行变异

查询给定资源时,您可以立即将返回的结果作为对象获取,修改这些对象,然后将其发回给相应资源服务中的 mutate 方法。以下是一个示例工作流程: 1. 执行查询,查找当前处于 PAUSED 状态且展示次数超过 1000 的所有广告系列。 1. 从响应中每个 GoogleAdsRowcampaign 字段获取 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> 替换为资源(例如 customercampaign)或字段(例如 campaign.idmetrics.impressionsad_group.id)。

如需查看可查询字段的列表,请参阅 GoogleAdsField 文档

代码示例

客户端库提供了有关如何在 GoogleAdsService 中使用 Google Ads 查询语言的示例。基本操作文件夹中也包含了各种示例,例如 GetCampaignsGetKeywordsSearchForGoogleAdsFields