セグメンテーションは、Google 広告 UI では個別のメニューとして利用できますが、クエリに適切なフィールドを追加するだけで Google Ads API で実装できます。たとえば、クエリに segments.device
を追加すると、レポートと FROM
句で指定されたリソースの組み合わせごとに行が記述され、統計値(インプレッション数、クリック数、コンバージョン数など)がレポートに分割されます。
Google 広告の管理画面では、一度に 1 つのセグメントしか使用できませんが、API では同じクエリで複数のセグメントを指定できます。
SELECT
campaign.name,
campaign.status,
segments.device,
metrics.impressions
FROM campaign
このクエリを GoogleAdsService.SearchStream
に送信した結果は、次の JSON 文字列のようになります。
{
"results":[
{
"campaign":{
"resourceName":"customers/1234567890/campaigns/111111111",
"name":"Test campaign",
"status":"ENABLED"
},
"metrics":{
"impressions":"10922"
},
"segments":{
"device":"MOBILE"
}
},
{
"campaign":{
"resourceName":"customers/1234567890/campaigns/111111111",
"name":"Test campaign",
"status":"ENABLED"
},
"metrics":{
"impressions":"28297"
},
"segments":{
"device":"DESKTOP"
}
},
...
]
}
上記のサンプル結果では、リソース名を含む 1 番目と 2 番目のオブジェクトの属性は同じです。インプレッションはデバイスごとに分割されるため、同じキャンペーンに対して 2 つ以上のオブジェクトを返すことができます。
暗黙的セグメント分割
すべてのレポートは、最初は FROM
句で指定されたリソースによってセグメント化されます。resource_name フィールドがクエリに明示的に含まれていなくても、FROM
句でリソースの resource_name フィールドが返されます。この指標は、それによってセグメント化されます。たとえば、FROM
句でリソースに ad_group
を指定すると、ad_group.resource_name
が自動的に返され、ad_group レベルで指標が暗黙的にセグメント化されます。
このクエリについて
SELECT metrics.impressions
FROM ad_group
以下のような JSON 文字列が得られます。
{
"results":[
{
"adGroup":{
"resourceName":"customers/1234567890/adGroups/2222222222"
},
"metrics":{
"impressions":"237"
}
},
{
"adGroup":{
"resourceName":"customers/1234567890/adGroups/33333333333"
},
"metrics":{
"impressions":"15"
}
},
{
"adGroup":{
"resourceName":"customers/1234567890/adGroups/44444444444"
},
"metrics":{
"impressions":"0"
}
}
]
}
ad_group
が FROM
句でリソースとして指定されたため、adGroup
の resource_name
フィールドは常に返されます。
選択可能なセグメント フィールド
FROM
句で、特定のリソースに対してすべてのセグメント フィールドを選択できるわけではありません。たとえば、引き続き ad_group
リソースからクエリを実行します。セグメント フィールドを ad_group リソースから選択できるようにするには、そのフィールドが ad_group の Segments
リストに存在する必要があります。Segments
リストは、ad_group
リソースのメタデータ ページで使用可能なフィールド テーブルの黄色の部分です。
リソースを分割する
一部のリソースから選択する場合に、FROM
句でリソースのフィールドとともにフィールドを選択することで、関連するリソースを暗黙的に結合できます。これらの関連リソースは、FROM
句のメタデータ ページにあるリソースの Attributed Resources
リストにあります。ad_group
リソースの場合、campaign
リソースからフィールドを選択することもできます。resource_name フィールドがクエリに明示的に含まれていなくても、SELECT
句に少なくとも 1 つのフィールドがある Attributed Resources
の resource_name フィールドが自動的に返されます。
Attributed Resource
フィールドの選択と同様に、Segmenting Resource
フィールドも選択できます。メタデータ ページに Segmenting Resources
リストがある場合、リストにあるリソースのいずれかからフィールドを選択すると、その Segmenting Resource
の resource_name でクエリがセグメント化されます。たとえば、campaign
リソースが campaign_budget
リソースの Segmenting Resource
としてリストされていることがわかります。campaign_budget リソースから campaign.name
などのキャンペーン フィールドを選択すると、campaign.name フィールドが返されるだけでなく、campaign.resource_name
フィールドが返され、セグメント分けされます。
セグメントと指標の選択性
特定のセグメント フィールドは、他のセグメント フィールドまたは指標フィールドと互換性がない場合があります。相互に互換性のあるセグメント フィールドを確認するには、SELECT
句でセグメントの selectable_with
リストを確認します。
ad_group
リソースの場合、50 以上の使用可能なセグメントを選択できます。ただし、segments.hotel_check_in_date
の selectable_with
リストは、はるかに小さな互換セグメントのセットです。つまり、segments.hotel_check_in_date
フィールドを SELECT
句に追加すると、選択可能な残りのセグメントがこれら 2 つのリストの交点に限定されます。
- 一部のセグメントを追加すると、集計行の指標が低下することがあります
FROM ad_group_ad
でクエリにsegments.keyword.info.match_type
を追加すると、そのセグメントはキーワードを含むデータの行のみを取得し、キーワードに関連付けられていない行を削除するようクエリに指示します。この場合、キーワード以外の指標がすべて除外されるため、指標が小さくなります。
WHERE 句のセグメントに関するルール
セグメントが WHERE
句に含まれている場合は、SELECT
句にも含まれている必要があります。このルールの例外は、コア期間セグメントと呼ばれる次の日付セグメントです。
segments.date
segments.week
segments.month
segments.quarter
segments.year
コア日付セグメント フィールドのルール
セグメント segments.date
、segments.week
、segments.month
、segments.quarter
、segments.year
は次のように機能します。
これらのセグメントは、
SELECT
句で指定せずにWHERE
句でフィルタできます。これらのセグメントのいずれかが
SELECT
句に含まれている場合、コア期間セグメントで構成される有限の期間をWHERE
句に指定する必要があります(日付セグメントはSELECT
で指定されたものと同じである必要はありません)。
例
無効: segments.date は SELECT 句にあるため、segments.date 、segments.week 、segments.month 、segments.quarter 、segments.year の WHERE 句で有限の期間を指定する必要があります。 |
SELECT campaign.name, metrics.clicks, segments.date FROM campaign |
有効: このクエリは、期間中に発生したキャンペーン名とクリック数を返します。なお、segments.date を SELECT 句に指定する必要はありません。 |
SELECT campaign.name, metrics.clicks FROM campaign WHERE segments.date > '2020-01-01' AND segments.date < '2020-02-01' |
有効: このクエリは、日付範囲内のすべての日付の日付で分割されたキャンペーン名とクリック数を返します。 |
SELECT campaign.name, metrics.clicks, segments.date FROM campaign WHERE segments.date > '2020-01-01' AND segments.date < '2020-02-01' |
有効: このクエリは、対象期間内のすべての日を対象に、月とセグメントで分割されたキャンペーン名とクリック数を返します。 |
SELECT campaign.name, metrics.clicks, segments.month FROM campaign WHERE segments.date > '2020-01-01' AND segments.date < '2020-02-01' |
有効: このクエリは、年ごとのすべての月を四半期、月ごとに分割したキャンペーン名とクリック数を返します。 |
SELECT campaign.name, metrics.clicks, segments.quarter, segments.month FROM campaign WHERE segments.year > 2015 AND segments.year < 2020 |
search_term_view
search_term_view
リソースについては、リソース名の構造(広告グループも含む)を反映するように、検索キーワードだけでなく広告グループによっても暗黙的にセグメント化されます。したがって、実際にはそれらの行が別の広告グループに属している場合、同じ検索キーワードを含む行が一見重複しているように見えます。
{
"results":[
{
"searchTermView":{
"resourceName":"customers/1234567890/searchTermViews/111111111~2222222222~Z29vZ2xlIHBob3RvcyBpb3M",
"searchTerm":"google photos"
},
"metrics":{
"impressions":"3"
},
"segments":{
"date":"2015-06-15"
}
},
{
"searchTermView":{
"resourceName":"customers/1234567890/searchTermViews/111111111~33333333333~Z29vZ2xlIHBob3RvcyBpb3M",
"searchTerm":"google photos"
},
"metrics":{
"impressions":"2"
},
"segments":{
"date":"2015-06-15"
}
}
]
}
この例で返される 2 つのオブジェクトは重複しているように見えますが、実際には「広告グループ」部分でリソース名が異なります。つまり、「google photos」という検索語句は、同じ日付(2015 年 6 月 15 日)の 2 つの広告グループ(ID 2222222222
と 33333333333
)に関連付けられます。したがって、この API は意図したとおりに動作し、この場合は重複したオブジェクトを返しなかったと結論付けられます。