Struktura zapytań i klauzule

Zapytanie składa się z kilku klauzul: SELECT, FROM, WHERE, ORDER BY, LIMITPARAMETERS.

Klauzule używają nazw pól, nazw zasobów, operatorów, warunkówustawień sortowania, które są łączone w pojedyncze żądanie zapytania.

Aby utworzyć zapytanie, musisz:

  • Określ zasób, z którego chcesz pobrać dane.
  • Dodaj pola i dane, aby określić, jakie dane mają zostać zwrócone.
  • Dodaj segmenty, aby grupować wyniki.
  • Dodaj przypisane zasoby, aby dołączyć do siebie powiązane dane zasobów.
  • filtrować, sortować i ograniczać wyniki;

SELECT klauzula

Klauzula SELECT:

  • Jest wymagany w zapytaniu.
  • Określa zestaw pól do pobrania w żądaniu.
  • Odbiera listę pól zasobów, kolumn niestandardowych, niestandardowych zmiennych Floodlight, pól segmentów i danych oddzielonych przecinkami, a potem zwraca wartości w odpowiedzi.

Z tego przykładowego zapytania dowiesz się, jak wybrać atrybuty zasobu campaign:

SELECT
  campaign.id,
  campaign.name
FROM campaign

Wiele typów pól

W jednym żądaniu możesz poprosić o różne typy pól.

Przykładowe zapytanie poniżej zawiera pojedyncze zapytanie z kombinacją:

  • Pola zasobu: campaign.id, campaign.name, bidding_strategy.idbidding_strategy.name.
  • Pola segmentu: segments.devicesegments.date.
  • Pola danych: metrics.impressionsmetrics.clicks.
SELECT
  campaign.id,
  campaign.name,
  bidding_strategy.id,
  bidding_strategy.name,
  segments.device,
  segments.date,
  metrics.impressions,
  metrics.clicks
FROM campaign
WHERE segments.date DURING LAST_30_DAYS

Aby dowiedzieć się więcej o dzielenie raportów wyszukiwania na segmenty, zapoznaj się z artykułem Segmentacja.

Pole głównego zasobu

Zwykle w klauzuli SELECT uwzględniasz główne pole zasobu, ale nie jest to wymagane (nie jest wymagane).

To przykładowe zapytanie używa pola głównego zasobu (ad_group.status) tylko do filtrowania wyników.

SELECT campaign.id
FROM ad_group
WHERE ad_group.status = PAUSED

Niestandardowe zmienne Floodlight

W klauzuli SELECT możesz uwzględniać niestandardowe zmienne Floodlight, podając ich identyfikatory.

W tym przykładzie zapytanie zawiera zmienną niestandardową o identyfikatorze 123454321 dla zasobu kampanii.

SELECT
  conversion_custom_metrics.id[123454321]
FROM campaign
SELECT
  conversion_custom_dimensions.id[123454321]
FROM campaign

Kolumny niestandardowe

W klauzuli SELECT możesz uwzględnić kolumny niestandardowe, podając ich identyfikatory.

W tym przykładzie zapytanie obejmuje kolumnę niestandardową o identyfikatorze 12345678 dla zasobu kampanii.

SELECT
  custom_columns.id[12345678]
FROM campaign

Dowiedz się, jak uzyskać identyfikatory kolumn niestandardowych.

Pola danych

Możesz wybrać pola danych dla danego zasobu bez uwzględniania innych pól tego zasobu w klauzuli SELECT.

To przykładowe zapytanie wybiera dane impressionsclicks dotyczące zasobu campaign.

SELECT
  metrics.impressions,
  metrics.clicks
FROM campaign

Na stronie metrics znajdziesz listę pól danych, których możesz używać w zapytaniach.

Pola segmentów

W klauzuli SELECT możesz wybierać pola segmentów bez określania towarzyszących pól zasobów ani danych.

W tym przykładzie zapytanie dzieli wyniki według urządzenia.

SELECT segments.device
FROM campaign

Na stronie segments znajdziesz listę pól segmentów, których możesz używać w zapytaniach.

Pola niedozwolone

W klauzuli SELECT nie można używać tych pól:

  • pola, których nie można wybrać, czyli pola z atrybutem metadanych Selectable oznaczonym jako false;
  • pola powtarzane, czyli pola z atrybutem metadanych Repeated oznaczone jako true;
  • pola, które nie są dostępne dla danego zasobu w klauzuli FROM. Atrybutów niektórych zasobów nie można wybierać razem. Niektóre zasoby udostępniają tylko podzbiór wszystkich danych i segmentów.
  • niezgodne segmenty lub dane. Więcej informacji znajdziesz w sekcji Podział na segmenty.

Szczegółowe informacje o tym, gdzie znaleźć te informacje w przypadku poszczególnych zasobów, znajdziesz w dokumentacji referencyjnej.

Klauzula FROM

Klauzula FROM:

  • Jest to wymagany element zapytań do tabeli SearchAds360Service (zarówno w przypadku metod Search, jak i SearchStream).
  • Nie należy uwzględniać jej w przypadku zapytań do SearchAds360FieldService.
  • Określa główny zasób zwracany przez zapytanie.
  • Możesz określić tylko 1 zasób.
  • Określa pola, których możesz używać we wszystkich pozostałych klauzulach w zapytaniu.

Przypisane zasoby

Jeśli dostępne są przypisane zasoby, są one dołączane do zasobu określonego w klauzuli FROM. Aby zwrócić ich wartości, wystarczy dodać ich atrybuty do klauzuli SELECT.

To przykładowe zapytanie zwraca zarówno identyfikator grupy reklam, jak i identyfikator kampanii, ponieważ zasób campaign jest przypisany do zasobu ad_group.

SELECT
  campaign.id,
  ad_group.id
FROM ad_group

Pole resource_name

Pole resource_name głównego zasobu w klauzuli FROM jest zawsze zwracane.

W tym przykładowym zapytaniu parametr ad_group.resource_name zostanie uwzględniony w odpowiedzi, mimo że nie został wyraźnie wybrany w zapytaniu:

SELECT ad_group.id
FROM ad_group

Gdy wybrane jest co najmniej 1 pole, zwracane jest pole resource_name przypisanego zasobu.

W tym przykładowym zapytaniu element campaign.resource_name zostanie uwzględniony w odpowiedzi, ponieważ wybrano element campaign.id:

SELECT
  campaign.id,
  ad_group.id
FROM ad_group

Klauzula WHERE

Klauzula WHERE:

  • Jest to opcjonalna klauzula w zapytaniu.
  • Określa warunki filtrowania i dzielenia na segmenty danych w ramach żądania. Warunki mają następujący format: FIELD_NAME OPERATOR VALUE (oddzielone spacjami).
  • Może zawierać wiele warunków oddzielonych separatorem AND.

Z tego przykładowego zapytania dowiesz się, jak za pomocą klauzuli WHERE zwracać dane impressions za wybrany okres:

SELECT
  campaign.id,
  campaign.name,
  metrics.impressions
FROM campaign
WHERE segments.date DURING LAST_30_DAYS

Aby dowiedzieć się więcej o dzielenie raportów wyszukiwania na segmenty, zapoznaj się z artykułem Segmentacja.

Więcej informacji o określaniu zakresów dat w zapytaniach znajdziesz w artykule Zakresy dat.

Filtrowanie według pola resource_name

Za pomocą pola resource_name możesz filtrować i sortować dane.

W tym przykładowym zapytaniu do filtrowania wyników według danej kampanii użyto pola campaign.resource_name:

SELECT
  campaign.id,
  campaign.name
FROM campaign
WHERE campaign.resource_name = 'customers/1234567/campaigns/987654'

Wiele warunków

Aby filtrować dane, możesz łączyć ze sobą wiele warunków.

To przykładowe zapytanie zwraca liczbę danych clicks dla wszystkich kampanii z danymi impressions na urządzeniach mobilnych z ostatnich 30 dni.

SELECT
  campaign.id,
  campaign.name,
  segments.device,
  metrics.clicks
FROM campaign
WHERE metrics.impressions > 0
  AND segments.device = MOBILE
  AND segments.date DURING LAST_30_DAYS

Aby dowiedzieć się więcej o podziale raportów na segmenty, zapoznaj się z artykułem Podział na segmenty.

Rozróżnianie wielkości liter

Podczas filtrowania według wartości ciągu znaków do prawidłowego filtrowania wyników ważne znaczenie ma domyślne rozróżnianie wielkości liter w przypadku każdego operatora.

Tabela poniżej pokazuje domyślną wielkość liter w przypadku każdego operatora.

Domyślne rozróżnianie wielkości liter
=/!= Case sensitive
IN/NOT IN Case sensitive
LIKE/NOT LIKE Case insensitive
CONTAINS (...) Case sensitive
REGEXP_MATCH/NOT REGEXP_MATCH Case sensitive

Za pomocą modyfikatora (?i) możesz zmienić domyślną czułość funkcji REGEXP_MATCH i NOT REGEXP_MATCH na nieczułą na wielkość liter, na przykład:

SELECT campaign.id
FROM campaign
WHERE campaign.name REGEXP_MATCH "(?i).*test.*"

Pełną listę operatorów, których możesz używać do filtrowania danych, znajdziesz w artykule Przewodnik po gramatyce zapytań.

Podstawowe segmenty dat

Te pola segmentów są nazywane głównymi segmentami dat: segments.date, segments.week, segments.month, segments.quartersegments.year.

W klauzuli WHERE możesz użyć podstawowych segmentów daty, aby określić datę lub czas.

W tym przykładowym zapytaniu w klauzuli WHERE dla pola segments.date podany jest parametr DURING LAST_30_DAYS:

SELECT
  campaign.id,
  campaign.name,
  segments.date,
  metrics.clicks
FROM campaign
WHERE segments.date DURING LAST_30_DAYS

Szczegółowe informacje o korzystaniu z podstawowych segmentów dat znajdziesz w sekcji Podział na segmenty > Podstawowe segmenty dat.

Zakazane filtrowanie

Filtrowanie jest niedozwolone w przypadku:

  • W niewybranych polach segmentu, z wyjątkiem podstawowych segmentów dat.
  • W polach dowolnego typu wiadomości z wyjątkiem typów prymitywnych (np. Int64Value, StringValue itp.).
  • W atrybutach pól powtarzanych dowolnego typu wiadomości, z wyjątkiem typów prymitywnych (np. Int64Value, StringValue itp.).

Klauzula ORDER BY

Klauzula ORDER BY:

  • Jest to opcjonalna klauzula w zapytaniu.
  • Określa kolejność, w jakiej zwracane są wyniki. Kolejność jest zgodna z tym wzorcem: FIELD_NAME ORDERING_OPTION (oddzielone spacją).
  • Dostępne są 2 opcje: ASC (rosnąco) lub DESC (malejąco). Domyślnie sortowanie jest rosnące.

To przykładowe zapytanie sortuje kampanie według liczby kliknięć w kolejności malejącej (od największej do najmniejszej):

SELECT
  campaign.name,
  metrics.clicks
FROM campaign
ORDER BY metrics.clicks DESC

Wiele zamówień

W klauzuli ORDER BY możesz podać wiele pól, korzystając z listy rozdzielonej przecinkami. Wyniki będą uporządkowane w tej samej kolejności, w jakiej zostały określone w zapytaniu.

To przykładowe zapytanie wybiera dane grupy reklam i porządkuje wyniki w kolejności rosnącej według nazwy kampanii, a potem w kolejności malejącej według liczby wyświetleń i potem w kolejności malejącej według liczby kliknięć:

SELECT
  campaign.name,
  ad_group.name,
  metrics.impressions,
  metrics.clicks
FROM ad_group
ORDER BY
  campaign.name,
  metrics.impressions DESC,
  metrics.clicks DESC

Połączenie sortowania i limitu

Aby doprecyzować wyniki, możesz użyć klauzuli ORDER BY w połączeniu z klauzulą LIMIT.

To przykładowe zapytanie zwraca 5 kampanii z największą liczbą wyświetleń w ciągu ostatnich 30 dni:

SELECT
  campaign.id,
  campaign.name,
  metrics.impressions
FROM campaign
WHERE segments.date DURING LAST_30_DAYS
ORDER BY metrics.impressions DESC
LIMIT 5

Zamówienie niedozwolone

Nie można zamówić:

  • według atrybutów niezaznaczonych zasobów;
  • według niewybranych danych.
  • według niewybranych segmentów.
  • W przypadku tych typów pól:
    • MESSAGE
    • Pola powtarzane
    • Atrybuty pól powtarzanych.

Klauzula LIMIT

Klauzula LIMIT:

  • Jest to opcjonalna klauzula w zapytaniu.
  • Umożliwia ograniczenie liczby wyników zwracanych przez zapytanie.

Ta klauzula jest przydatna np. wtedy, gdy interesuje Cię tylko próbka lub podsumowanie wyników.

To przykładowe zapytanie ogranicza łączną liczbę wyników do 50:

SELECT
  campaign.name,
  ad_group.name,
  segments.device,
  metrics.impressions
FROM ad_group
ORDER BY metrics.impressions DESC
LIMIT 50

Klauzula PARAMETERS

Klauzula PARAMETERS umożliwia określenie metaparametrów żądania.

Uwzględnij wersje robocze

Parametr include_drafts określa, czy w wynikach mają być uwzględniane elementy w wersji roboczej. Wartość domyślna to false. Aby uwzględnić elementy w wersji roboczej, ustaw tę wartość na true.

To przykładowe zapytanie zwraca zarówno wersje robocze kampanii, jak i zwykłe kampanie:

SELECT campaign.name
FROM campaign
PARAMETERS include_drafts=true

Pomiń niewybrane resource_name

Parametr omit_unselected_resource_names umożliwia wykluczenie pola resource_name ze wszystkich zasobów, które nie zostały wyraźnie zażądane w klauzuli SELECT. Wartość domyślna to false. Jeśli ustawisz ten parametr na wartość true, zalecamy jawne zapytanie o nazwę zasobu podstawowego oraz o wszystkie przypisane zasoby w klauzuli SELECT.

To przykładowe zapytanie nie zwraca ani pola campaign.resource_name, ani pola customer.resource_name, ponieważ nie są one uwzględnione w klauzuli SELECT:

SELECT
  campaign.name,
  customer.id
FROM campaign
PARAMETERS omit_unselected_resource_names = true

To przykładowe zapytanie zwraca pole campaign.resource_name, ponieważ jest ono wyraźnie wymagane w nawiasach klamrowych SELECT:

SELECT
  campaign.name,
  campaign.resource_name
FROM campaign
PARAMETERS omit_unselected_resource_names = true

Zmiana waluty używanej w danych

Parametr metrics_currency umożliwia określenie waluty, której ma być używana do obliczania danych uwzględnionych w klauzuli SELECT. Domyślnie używana jest waluta lokalna konta. Jeśli ustawisz ten parametr, musisz użyć 3-literowego kodu waluty ISO 4217. Przykład: PLN, EUR.

To przykładowe zapytanie zwraca dane cost_micros w walucie lokalnej konta.

SELECT
  campaign.name,
  metrics.cost_micros
FROM campaign
WHERE segments.date >= "2018-08-15"
AND segments.date < "2018-08-16"

To przykładowe zapytanie zwraca dane cost_micros w peso chilijskich (CLP).

SELECT
  campaign.name,
  metrics.cost_micros
FROM campaign
WHERE segments.date >= "2018-08-15"
AND segments.date < "2018-08-16"
PARAMETERS metrics_currency = "CLP"

Włączanie rozszerzenia MCC

Jeśli parametr enable_mcc_expansion ma wartość true, możesz uwzględnić dane, pola i segmenty z poziomu login_customer_id oraz wszystkich kont wyświetlania pod nim w przypadku zasobu w klauzuli FROM. Odpowiedź będzie używać waluty login_customer_id, chyba że w parametrze metrics_currency zostanie podana inna waluta.

To przykładowe zapytanie zwraca wartości bidding_strategy.name, bidding_strategy.typemetrics.cost_micros z poziomu login_customer_id oraz wszystkich kont obsługi, ponieważ parametr enable_mcc_expansion ma wartość true.

SELECT
  bidding_strategy.name,
  bidding_strategy.type,
  metrics.cost_micros
FROM bidding_strategy
WHERE segments.date DURING LAST_14_DAYS
PARAMETERS enable_mcc_expansion = true

Więcej informacji