Google Ads 쿼리 언어

Google Ads 쿼리 언어는 Google Ads API를 쿼리하여

리소스 및 관련 속성, 세그먼트 및 측정항목을
GoogleAdsService 검색 또는 SearchStream
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

이 쿼리는 캠페인 ID를 기준으로 정렬하면서 상태가 PAUSED이고 노출수가 1, 000회 이상인 캠페인만 필터링합니다. 결과로 반환되는 각 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이고 노출수가 1,000회 이상인 캠페인만 필터링합니다. 하지만 이 쿼리는 데이터를 날짜별로 분류합니다. 이렇게 하면 결과적인 각 GoogleAdsRow이 캠페인의 튜플과 날짜 Segment를 나타냅니다. 세그먼트를 분류하면 선택한 측정항목이 분할되어 SELECT 절에서 각 세그먼트별로 그룹화된다는 점에 유의해야 합니다.

쿼리 가능한 세그먼트의 목록은 Segments 문서를 참고하세요.

특정 리소스에 대한 쿼리에서 사용 가능한 경우 다른 관련 리소스에 대해 조인할 수 있습니다. 이러한 관련 리소스를 '기여 리소스'라고 합니다. 쿼리에서 속성을 선택하여 기여 분석 리소스에 암시적으로 조인할 수 있습니다.

SELECT
  campaign.id,
  campaign.name,
  campaign.status,
  bidding_strategy.name
FROM campaign
ORDER BY campaign.id

이 쿼리는 캠페인 속성을 선택할 뿐만 아니라 선택한 각 캠페인에서 관련 속성을 가져옵니다. 결과로 반환되는 각 GoogleAdsRow는 선택된 캠페인 속성과 선택된 입찰 전략 속성 bidding_strategy.name로 채워진 campaign 객체를 나타냅니다.

캠페인 쿼리에 사용할 수 있는 기여 분석 리소스를 알아보려면 Campaign 참조 문서를 확인하세요.

쿼리 결과에 따른 변경

특정 리소스를 쿼리할 때 반환된 결과를 즉시 객체로 가져와서 수정한 후 해당 리소스 서비스의 변형 메서드로 다시 보낼 수 있습니다. 다음은 샘플 워크플로입니다.

  1. 현재 PAUSED이고 노출수가 1,000보다 큰 모든 캠페인에 대해 쿼리를 실행합니다.
  2. 응답에 있는 각 GoogleAdsRow에 있는 campaign 필드에서 Campaign 객체를 가져옵니다.
  3. 각 캠페인의 상태를 PAUSED에서 ENABLED로 변경합니다.
  4. 수정된 캠페인과 함께 CampaignService.MutateCampaigns를 호출하여 업데이트합니다.

필드 메타데이터

GoogleAdsFieldService로 전송된 쿼리는 필드 메타데이터를 검색하기 위한 것입니다. 이 정보를 사용하여 쿼리에서 필드를 함께 사용하는 방법을 파악할 수 있습니다. 데이터는 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와 같은 예가 있습니다. reporting 폴더에는 GetKeywordStats 예가 있습니다.