Search Ads 360 Reporting API で検索レポートを作成する方法については、以下のセクションをご覧ください。
検索サービス
Search Ads 360 Reporting API は、検索とレポート作成のための特別なサービスを提供します。
SearchAds360Service は、オブジェクトの取得とレポートを統合したサービスです。SearchStream と Search の 2 つの検索方法が用意されています。検索は、検索広告 360 のクエリ言語で記述されたクエリ文字列で渡されます。クエリを定義して、次のことができます。
- オブジェクトの属性を取得します。
- 期間に基づいてオブジェクトの統計情報の指標を取得します。
- オブジェクトに基づいてオブジェクトを並べ替えます。
- 返すオブジェクトを指定する条件を使用して結果をフィルタする
- 返されるオブジェクトの数を制限します。
どちらの検索方法でも、クエリに一致するすべての行が返されます。たとえば、campaign.id、campaign.name、metrics.clicks を取得すると、id フィールドと name フィールドが設定されたキャンペーン オブジェクトと、clicks フィールドが設定された metrics オブジェクトを含む SearchAds360Row が返されます。
検索方法
SearchStreamレポートのサイズに関係なく、1 つのリクエストを送信し、Search Ads 360 Reporting API との永続的な接続を開始します。
- データパケットはすぐにダウンロードを開始し、結果全体がデータバッファにキャッシュに保存されます。
- ストリーム全体が完了するのを待たずに、バッファ内のデータの読み取りをコードで開始できます。
Search複数のページネーション リクエストを送信して、レポート全体をダウンロードします。
SearchStream は、個々のページをリクエストするために必要なネットワークの往復時間を排除するため、通常はパフォーマンスが向上します。行数が 10,000 行を超えるすべてのレポートには、SearchStream を使用することをおすすめします。比較的小さいレポート(10,000 行未満)では、メソッド間でパフォーマンスに大きな違いはありません。
使用する方法は API の割り当てと上限には影響しません。結果がページングされるかストリーミングされるかにかかわらず、1 つのクエリまたはレポートは 1 つのオペレーションとしてカウントされます。
検索クエリの例
次のサンプルクエリは、過去 30 日間のアカウントのパフォーマンス データを、デバイス別にキャンペーン別に返します。
SELECT
campaign.name,
campaign.status,
segments.device,
metrics.impressions,
metrics.clicks,
metrics.ctr,
metrics.average_cpc,
metrics.cost_micros
FROM campaign
WHERE segments.date DURING LAST_30_DAYS
リクエストを作成する
リクエストを送信するには、customer_id 文字列と query 文字列を SearchAds360Service.SearchStream インターフェースまたは SearchAds360Service.Search インターフェースに渡す必要があります。
リクエストは、次のいずれかの URL にある Search Ads 360 Reporting API サーバーへの HTTP POST で構成されます。
https://searchads360.googleapis.com/VERSION_NUMBER/customers/CUSTOMER_ID/searchads360:searchStream
https://searchads360.googleapis.com/VERSION_NUMBER/customers/CUSTOMER_ID/searchads360:search
HTTP POST リクエストに格納される searchStream のレポート定義の例を次に示します。
POST /VERSION_NUMBER/customers/CUSTOMER_ID/searchads360:searchStream HTTP/1.1 Host: searchads360.googleapis.com User-Agent: curl Content-Type: application/json Accept: application/json Authorization: Bearer [OAUTH_2.0_ACCESS_TOKEN] Parameters: { "query" : "SELECT campaign.name, campaign.status, segments.device, metrics.impressions, metrics.clicks, metrics.ctr, metrics.average_cpc, metrics.cost_micros FROM campaign WHERE segments.date DURING LAST_30_DAYS" }
レスポンスを処理する
SearchAds360Service は、SearchAds360Row オブジェクトのリストを返します。
各 SearchAds360Row はクエリによって返されるオブジェクトを表します。各オブジェクトは、クエリの SELECT 句でリクエストされたフィールドに基づいて入力される一連の属性で構成されます。SELECT 句に含まれていない属性は、レスポンスのオブジェクトに入力されません。
たとえば、次のクエリでは、各 SearchAds360Row オブジェクトに campaign.id、campaign.name、campaign.status のみが入力されます。campaign.engine_id や campaign.bidding_strategy_type などの他の属性は省略されます。
SELECT
campaign.id,
campaign.name,
campaign.status
FROM campaign
リファレンス ドキュメント
[参照] セクションには、各アーティファクトを正しく使用するために必要な情報がすべて含まれています。リソースごとに 1 つのページがあります(ad_group や campaign など)。[segments] ページと [metrics] ページには、使用可能なすべてのセグメントと指標フィールドが一覧表示されます。
リソース、セグメント、指標には、互換性がなく一緒に使用できないものもあれば、完全に互換性があり、相互に補完するものもあります。各リソースページには、次の情報が(利用可能で適切な場合に)含まれています。
- アトリビューション リソース
一部のリソースでは、
FROM句でリソースのフィールドとともに関連リソースのフィールドを選択することで、関連リソースを暗黙的に結合できます。たとえば、campaignリソースは、ad_groupリソースの属性リソースです。つまり、FROM句でad_groupを使用する場合は、campaign.idやcampaign.bidding_strategy_typeなどのフィールドをクエリに含めることができます。[アトリビューション リソース] セクションには、使用可能なアトリビューション リソースが一覧表示されます。すべてのリソースにアトリビュート リソースが設定されているわけではありません。
- リソース フィールド列
リソースのすべてのフィールドが [リソース フィールド] 列に含まれます。各リソース フィールドは、フィールドの詳細(説明、カテゴリ、データ型、タイプ URL、フィルタ、選択、並べ替え、繰り返しの設定など)へのリンクになっています。
- [セグメント] 列
特定のリソースですべてのセグメント フィールドを選択できるわけではありません。
[セグメント] 列には、リソースのフィールドと同じ
SELECT句で使用できるsegmentsフィールドが一覧表示されます。各フィールドには、説明、カテゴリ、データ型、URL 型、フィルタ可能、選択可能、並べ替え可能、繰り返し設定など、フィールドの詳細情報へのリンクがあります。FROM句でリソースを使用している場合は、[Yes/No] プルダウンを使用して、使用できないセグメントを除外できます。- 指標列
特定のリソースですべての指標フィールドを選択できるわけではありません。
[指標] 列には、リソースのフィールドと同じ
SELECT句で使用できるmetricsフィールドが一覧表示されます。各フィールドは、フィールドの詳細(説明、カテゴリ、データ型、タイプ URL、フィルタ、選択、並べ替え、繰り返しの設定など)にリンクしています。FROM句でリソースを使用している場合は、[Yes/No] プルダウンを使用して、使用できない指標を除外します。
- リソースのセグメンテーション
一部のリソースには、リソースが
FROM句にあるときに選択できるセグメンテーション リソース フィールドがあります。たとえば、campaign.nameなどのcampaignリソース フィールドを選択した場合、FROM句でcampaign_budgetを使用すると、campaignはcampaign_budgetのセグメンテーション リソースであるため、campaign.resource_nameが自動的に返され、セグメント化されます。[セグメンテーション リソース] セクションには、使用可能なセグメンテーション リソースが一覧表示されます。すべてのリソースにセグメンテーション リソースがあるわけではありません。
- 選択可能な項目
一部の
segmentsフィールドは、他のリソース、セグメント、指標と互換性がありません。[
segments] ページには、segmentsフィールドごとに [Selectable with] が展開され、SELECT句に含めることができる、互換性のあるすべてのリソース フィールド、metricsフィールド、その他のsegmentsフィールドが一覧表示されます。
セグメンテーション
検索結果をセグメント化するには、クエリの SELECT 句に segments.FIELD_NAME フィールドを追加します。
たとえば、次のクエリの segments.device は、FROM 句で指定されたリソースの各デバイスの impressions の行を含むレポートを生成します。
SELECT
campaign.name,
campaign.status,
segments.device,
metrics.impressions
FROM campaign
SearchAds360Service.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"
}
},
...
]
}
使用可能なセグメント フィールドの一覧については、segments をご覧ください。
複数のセグメント
クエリの SELECT 句で複数のセグメントを指定できます。レスポンスには、FROM 句で指定されたメインリソースのインスタンスの組み合わせと、選択された各 segment フィールドの値ごとに 1 つの SearchAds360Row オブジェクトが含まれます。
たとえば、次のクエリは、campaign、segments.ad_network_type、segments.date の組み合わせごとに 1 行を返します。
SELECT
segments.ad_network_type
segments.date
FROM campaign
結果は、選択された個々のフィールドの値ではなく、メインリソースの各インスタンスごとに無条件にセグメント化されます。
次の例のクエリでは、campaign.status フィールドの個別の値ごとに 1 行ではなく、キャンペーンごとに 1 行が返されます。
SELECT
campaign.status,
metrics.impressions
FROM campaign
WHERE segments.date DURING LAST_14_DAYS
暗黙的セグメント分割
どのレポートも最初に FROM 句で指定されたリソースでセグメント化されます。指標は、このリソースの resource_name フィールドで分割されます。
このサンプルクエリは ad_group.resource_name を自動的に返します。また、暗黙的に 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"
}
}
]
}
コア日付セグメント
WHERE 句でコア日付セグメントを使用して、日付または期間を指定できます。
次のセグメント フィールドは、コア日付セグメントと呼ばれます。segments.date、segments.week、segments.month、segments.quarter、segments.year。
次のサンプルクエリは、過去 30 日間のキャンペーンの clicks 指標を返します。
SELECT
campaign.id,
campaign.name,
segments.date,
metrics.clicks
FROM campaign
WHERE segments.date DURING LAST_30_DAYS
コア日付セグメント フィールドは、SELECT 句にもフィールドを含めない限り、WHERE 句でセグメント フィールドを使用できないという一般的なルールの例外です。詳細については、禁止されているフィルタリングをご覧ください。
中核となる日付セグメントのルール:
コア日付フィールドは、
SELECT句に含めなくてもWHERE句で使用できます。必要に応じて、両方の句にフィールドを含めることもできます。このサンプルクエリは、期間中のキャンペーン名別の
clicks指標を返します。なお、segments.dateはSELECT句に含まれていません。SELECT campaign.name, metrics.clicks FROM campaign WHERE segments.date > '2022-02-01' AND segments.date < '2022-03-01'SELECT句に主要な日付フィールドを含める場合は、WHERE句で有限日または期間を指定する必要があります。SELECT句とWHERE句で指定するフィールドは一致する必要はありません。この例のクエリは、期間内のすべての日について、キャンペーン名と月別に分割された
clicks指標を返します。SELECT campaign.name, metrics.clicks, segments.month FROM campaign WHERE segments.date > '2022-02-01' AND segments.date < '2022-03-01'
ISO 8601 の日付
YYYY-MM-DD(ISO 8601)形式を使用して、日付と期間を指定できます。次に例を示します。
WHERE segments.date BETWEEN '2022-06-01' AND '2022-06-30'
WHERE segments.date >= '2022-06-01' AND segments.date <= '2022-06-30'
期間(segments.week、segments.month、segments.quarter)が必要な主要な日付セグメントの場合、期間の最初の日に対して = 演算子を使用できます。次に例を示します。
WHERE segments.month = '2022-06-01'
事前定義された日付
事前定義された次の期間も使用できます。
| 事前定義された日付 | |
|---|---|
TODAY |
本日のみ。 |
YESTERDAY |
昨日のみ。 |
LAST_7_DAYS |
過去 7 日間(今日は含まない)。 |
LAST_BUSINESS_WEEK |
前の 5 営業日(月~金)。 |
THIS_MONTH |
今月のすべての日。 |
LAST_MONTH |
先月のすべての日。 |
LAST_14_DAYS |
過去 14 日間(本日を除く)。 |
LAST_30_DAYS |
過去 30 日間(本日を除く)。 |
THIS_WEEK_SUN_TODAY |
前の日曜日から今日までの期間 |
THIS_WEEK_MON_TODAY |
前の月曜日から今日までの期間 |
LAST_WEEK_SUN_SAT |
前の日曜日から始まる 7 日間。 |
LAST_WEEK_MON_SUN |
前の月曜日から始まる 7 日間。 |
例:
WHERE segments.date DURING LAST_30_DAYS
指標なし
クエリを実行すると、一部のエンティティの値がゼロの指標が取得されることがあります。クエリでゼロの指標を処理する方法について学習する。
不明な列挙型
リソースが UNKNOWN 列挙型データ型で返される場合、その型は API バージョンで完全にサポートされていないことを意味します。これらのリソースは、他のインターフェースを通じて作成されている可能性があります。たとえば、検索広告 360 の管理画面で新しいキャンペーンや広告が導入されたものの、クエリを実行する API バージョンではまだサポートされていない場合です。
リソースのタイプが UNKNOWN の場合でも指標を選択できますが、次の点に注意する必要があります。
UNKNOWNタイプのリソースは後でサポートされる可能性がありますが、UNKNOWNのままになる可能性もあります。UNKNOWNタイプの新しいオブジェクトはいつでも表示される可能性があります。これらのオブジェクトには、列挙値がすでに利用できるため、下位互換性があります。この変更が適用されたリソースが利用可能になり次第、アカウントを正確に把握できるようにリリースします。UNKNOWNリソースは、他のインターフェースを介したアカウントでの新しいアクティビティが原因で、またはリソースが正式にサポートされなくなったために表示されることがあります。UNKNOWNリソースには、クエリ可能な詳細な指標が関連付けられている場合があります。UNKNOWNリソースは通常、検索広告 360 の管理画面にすべて表示されます。