Google Ads 쿼리 언어

Google Ads 쿼리 언어는

리소스와 관련 속성, 세그먼트, 측정항목은
GoogleAdsService Search 또는 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

이 쿼리는 상태가 PAUSED이고 노출수가 1, 000회 이상인 캠페인만 필터링하여 캠페인 ID를 기준으로 정렬합니다. 이렇게 반환되는 각 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 참조 문서를 확인하세요.

쿼리 결과에 따라 변형

특정 리소스를 쿼리할 때 반환된 결과를 즉시 객체로 취하여 수정한 후 해당 리소스의 서비스에 있는 Variant 메서드로 다시 보낼 수 있습니다. 다음은 샘플 워크플로입니다.

  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 예가 있습니다.