W tym artykule opisano format i schemat danych usług w Google Analytics 4 i danych Google Analytics dla Firebase eksportowanych do BigQuery.
Zbiory danych
Dla poszczególnych usług w Google Analytics 4 i projektów Firebase połączonych z BigQuery dodawany jest do projektu BigQuery pojedynczy zbiór danych o nazwie „analytics_<identyfikator_usługi>”. Identyfikator usługi to Twój identyfikator usługi w Analytics, który możesz znaleźć w ustawieniach usługi w Google Analytics 4 i w ustawieniach analityki aplikacji w Firebase. Każda usługa w Google Analytics 4 i każda aplikacja, dla której włączono eksportowanie BigQuery, wyeksportuje dane do tego pojedynczego zbioru danych.
Tabele
Jeśli opcja dziennego eksportu jest włączona, w każdym zbiorze danych jest codziennie tworzona tabela o nazwie events_YYYYMMDD
.
Jeśli masz włączoną opcję eksportu strumieniowego, tworzona jest tabela o nazwie events_intraday_YYYYMMDD
. Ta tabela jest wypełniana na bieżąco, w miarę rejestrowania zdarzeń w ciągu dnia. Tabela jest usuwana na koniec każdego dnia po utworzeniu tabeli events_YYYYMMDD
.
Nie wszystkie urządzenia, na których zdarzenia wystąpiły, wysyłają dane do Analytics w dniu, w którym zdarzenia zostały wywołane. Aby uwzględnić to opóźnienie, Analytics aktualizuje tabele dzienne (events_YYYYMMDD
) przy użyciu danych zdarzeń wywołanych w tych dniach przez maksymalnie 3 dni po dacie zdarzenia. Niezależnie od opóźnienia zdarzenia mają prawidłową sygnaturę czasową. Zdarzenia, które wystąpiły po upływie tego trzydniowego okresu, nie są rejestrowane.
Jeśli używasz piaskownicy BigQuery, nie masz dostępnego importowania danych częściowych o zdarzeniach oraz obowiązują Cię dodatkowe limity.
Jeśli chcesz importować dane częściowe, uaktualnij piaskownicę do pełnej wersji narzędzia.
Kolumny
Każda kolumna w tabeli events_YYYYMMDD
odpowiada parametrowi związanemu ze zdarzeniem. Niektóre parametry są zagnieżdżone w rekordach, z których część, np. items
i event_params
, jest powtarzalna. Kolumny tabeli zostały opisane poniżej.
Pola zdarzenia zawierają informacje, które jednoznacznie identyfikują zdarzenie. | ||
Nazwa pola | Typ danych | Opis |
---|---|---|
batch_event_index | INTEGER | Liczba wskazująca kolejność poszczególnych zdarzeń w grupie na podstawie ich kolejności występowania na urządzeniu. |
batch_ordering_id | INTEGER | Liczba rosnąca monotonicznie, która jest zwiększana za każdym razem, gdy z danej strony wysyłane jest żądanie sieciowe. |
batch_page_id | INTEGER | Numer sekwencyjny przypisany do strony, który rośnie w przypadku każdej kolejnej strony w ramach interakcji. |
event_date | STRING | Data rejestracji zdarzenia (w formacie RRRRMMDD i w strefie czasowej aplikacji). |
event_timestamp | INTEGER | Czas zarejestrowania tego zdarzenia przez klienta (w mikrosekundach, UTC). |
event_previous_timestamp | INTEGER | Czas poprzedniego zarejestrowania tego zdarzenia przez klienta (w mikrosekundach, UTC). |
event_name | STRING | Nazwa zdarzenia. |
event_value_in_usd | LICZBA ZMIENNOPRZECINKOWA | Wartość parametru „wartość” zdarzenia przeliczona na walutę (w USD). |
event_bundle_sequence_id | INTEGER | Identyfikator sekwencyjny zestawu, w którym zostały przesłane te zdarzenia. |
event_server_timestamp_offset | INTEGER | Przesunięcie sygnatury czasowej (w mikrosekundach) między godziną zebrania danych a godziną ich przesłania. |
REKORD event_params
Rekord event_params może przechowywać parametry zdarzenia na poziomie kampanii i kontekstowe, a także dowolne parametry zdarzenia zdefiniowane przez użytkownika. Rekord ten jest powtarzany w przypadku każdego klucza powiązanego ze zdarzeniem. Zestaw parametrów zapisanych w rekordzie event_params jest unikalny dla każdej implementacji. Aby zobaczyć pełną listę parametrów zdarzenia występujących w Twojej implementacji, wyślij zapytanie do listy tych parametrów. |
||
Nazwa pola | Typ danych | Opis |
---|---|---|
event_params.key | STRING | Nazwa parametru zdarzenia. |
event_params.value | RECORD | Rekord zawierający wartość parametru zdarzenia. |
event_params.value.string_value | STRING | Jeśli parametr zdarzenia jest ciągiem znaków, jak np. adres URL czy nazwa kampanii, zostaje wypełniony w tym polu. |
event_params.value.int_value | INTEGER | Jeśli parametr zdarzenia jest liczbą całkowitą, zostaje wypełniony w tym polu. |
event_params.value.double_value | LICZBA ZMIENNOPRZECINKOWA | Jeśli parametr zdarzenia jest wartością podwójnej precyzji, zostaje wypełniony w tym polu. |
event_params.value.float_value | LICZBA ZMIENNOPRZECINKOWA | Jeśli parametr zdarzenia jest liczbą zmiennoprzecinkową, zostaje wypełniony w tym polu. To pole nie jest obecnie używane. |
Rekord item_params
Rekord item_params może przechowywać dowolne parametry produktów zdefiniowane przez użytkownika. Zestaw parametrów zapisanych w rekordzie item_params jest unikalny dla każdej implementacji. |
||
Nazwa pola | Typ danych | Opis |
---|---|---|
item_params.key | STRING | Nazwa parametru produktu. |
item_params.value | RECORD | Rekord zawierający wartość parametru produktu. |
item_params.value.string_value | STRING | Jeśli parametr produktu jest ciągiem znaków, zostaje wypełniony w tym polu. |
item_params.value.int_value | INTEGER | Jeśli parametr produktu jest liczbą całkowitą, zostaje wypełniony w tym polu. |
item_params.value.double_value | LICZBA ZMIENNOPRZECINKOWA | Jeśli parametr produktu jest wartością podwójnej precyzji, zostaje wypełniony w tym polu. |
item_params.value.float_value | LICZBA ZMIENNOPRZECINKOWA | Jeśli parametr produktu jest liczbą zmiennoprzecinkową, zostaje wypełniony w tym polu. |
Pola użytkownika zawierają informacje, które jednoznacznie identyfikują użytkownika powiązanego ze zdarzeniem. | ||
Nazwa pola | Typ danych | Opis |
---|---|---|
is_active_user | WARTOŚĆ LOGICZNA |
Określa, czy użytkownik był aktywny (True – prawda) czy nieaktywny (False – fałsz) w dowolnym momencie w dniu kalendarzowym. Uwzględniany tylko w tabelach dziennych ( |
user_id | STRING | Unikalny identyfikator przypisany do użytkownika. |
user_pseudo_id | STRING | Pseudonimowy identyfikator użytkownika (np. identyfikator instancji aplikacji). |
user_first_touch_timestamp | INTEGER | Godzina (w mikrosekundach), o której użytkownik po raz pierwszy otworzył aplikację lub odwiedził witrynę. |
Pola privacy_info
Pola privacy_info zawierają informacje uzyskane na podstawie stanu zgody użytkownika, gdy włączony jest tryb uzyskiwania zgody. | ||
Nazwa pola | Typ danych | Opis |
---|---|---|
privacy_info.ads_storage | STRING |
Określa, czy na koncie użytkownika włączone jest kierowanie reklam. Możliwe wartości: Yes (Tak), No (Nie), Unset (Nie określono) |
privacy_info.analytics_storage | STRING |
Określa, czy na koncie użytkownika włączone jest zapisywanie danych Analytics. Możliwe wartości: Yes (Tak), No (Nie), Unset (Nie określono) |
privacy_info.uses_transient_token | STRING |
Określa, czy użytkownik internetu odmówił zapisywania danych Analytics, a programista włączył pomiar bez użycia plików cookie, korzystając z tokenów tymczasowych dostępnych w danych serwera. Możliwe wartości: Yes (Tak), No (Nie), Unset (Nie określono) |
REKORD user_properties
Rekord user_properties zawiera ustawione przez Ciebie właściwości użytkownika. Jest powtarzany w przypadku każdego klucza powiązanego z użytkownikiem. | ||
Nazwa pola | Typ danych | Opis |
---|---|---|
user_properties.key | STRING | Nazwa właściwości użytkownika. |
user_properties.value | RECORD | Rekord z wartością właściwości użytkownika. |
user_properties.value.string_value | STRING | Wartość ciągu przypisana do właściwości użytkownika. |
user_properties.value.int_value | INTEGER | Wartość liczby całkowitej przypisana do właściwości użytkownika. |
user_properties.value.double_value | LICZBA ZMIENNOPRZECINKOWA | Wartość podwójnej precyzji przypisana do właściwości użytkownika. |
user_properties.value.float_value | LICZBA ZMIENNOPRZECINKOWA | To pole nie jest obecnie używane. |
user_properties.value.set_timestamp_micros | INTEGER | Czas ostatniego ustawienia właściwości użytkownika (w mikrosekundach). |
Rekord user_ltv
Rekord user_ltv zawiera informacje o wartości użytkownika od początku śledzenia. W tabelach danych częściowych rekord ten nie jest wypełniany. | ||
Nazwa pola | Typ danych | Opis |
---|---|---|
user_ltv.revenue | LICZBA ZMIENNOPRZECINKOWA | Wartość użytkownika od początku śledzenia (przychód). W tabelach częściowych pole to nie jest wypełniane. |
user_ltv.currency | STRING | Wartość użytkownika od początku śledzenia (waluta). W tabelach danych częściowych pole to nie jest wypełniane. |
Rekord device zawiera informacje o urządzeniu, z którego pochodzi zdarzenie. | ||
Nazwa pola | Typ danych | Opis |
---|---|---|
device.category | STRING | Kategoria urządzenia (komórka, tablet lub komputer). |
device.mobile_brand_name | STRING | Marka urządzenia. |
device.mobile_model_name | STRING | Nazwa modelu urządzenia. |
device.mobile_marketing_name | STRING | Nazwa marketingowa urządzenia. |
device.mobile_os_hardware_model | STRING | Informacje o modelu urządzenia pobrane bezpośrednio z systemu operacyjnego. |
device.operating_system | STRING | System operacyjny urządzenia. |
device.operating_system_version | STRING | Wersja systemu operacyjnego. |
device.vendor_id | STRING | IDFV (tylko gdy identyfikator IDFA nie został zebrany). |
device.advertising_id | STRING | Identyfikator wyświetlania reklam / IDFA. |
device.language | STRING | Język systemu operacyjnego. |
device.time_zone_offset_seconds | INTEGER | Przesunięcie w stosunku do strefy czasowej GMT (w sekundach). |
device.is_limited_ad_tracking | WARTOŚĆ LOGICZNA |
Ustawienie ograniczenia śledzenia reklam na urządzeniu. W przypadku iOS w wersji 14 lub nowszej zwraca wartość „fałsz”, jeśli identyfikator IDFA ma wartość różną od 0. |
device.web_info.browser | STRING | Przeglądarka, w której użytkownik przeglądał treści. |
device.web_info.browser_version | STRING | Wersja przeglądarki, w której użytkownik przeglądał treści. |
device.web_info.hostname | STRING | Nazwa hosta powiązana z zarejestrowanym zdarzeniem. |
geo
Rekord geo zawiera informacje o lokalizacji geograficznej, w której zostało zainicjowane zdarzenie. | ||
Nazwa pola | Typ danych | Opis |
---|---|---|
geo.continent | STRING | Kontynent, z którego zostały zgłoszone zdarzenia, określony na podstawie adresu IP. |
geo.sub_continent | STRING | Subkontynent, z którego zostały zgłoszone zdarzenia, określony na podstawie adresu IP. |
geo.country | STRING | Kraj, z którego zostały zgłoszone zdarzenia, określony na podstawie adresu IP. |
geo.region | STRING | Region, z którego zostały zgłoszone zdarzenia, określony na podstawie adresu IP. |
geo.metro | STRING | Obszar miejski, z którego zostały zgłoszone zdarzenia, określony na podstawie adresu IP. |
geo.city | STRING | Miasto, z którego zostały zgłoszone zdarzenia, określone na podstawie adresu IP. |
Rekord app_info zawiera informacje o aplikacji, w której wystąpiło zdarzenie. | ||
Nazwa pola | Typ danych | Opis |
---|---|---|
app_info.id | STRING | Nazwa pakietu lub identyfikator pakietu aplikacji. |
app_info.firebase_app_id | STRING | Identyfikator aplikacji Firebase powiązany z aplikacją. |
app_info.install_source | STRING | Sklep, z którego zainstalowano aplikację. |
app_info.version | STRING | Wartość parametru versionName (Android) lub skrócona wersja pakietu. |
Rekord collect_traffic_source zawiera dane o źródle wizyty, które zostały zebrane ze zdarzeniem. |
||
Nazwa pola | Typ danych | Opis |
---|---|---|
manual_campaign_id | STRING | Identyfikator kampanii ręcznej (utm_id), który został zebrany ze zdarzeniem. |
manual_campaign_name | STRING | Nazwa kampanii ręcznej (utm_campaign), która została zebrana ze zdarzeniem. |
manual_source | STRING | Źródło kampanii ręcznej (utm_source), które zostało zebrane ze zdarzeniem. Obejmuje też parametry odtworzone z parametrów odesłania, a nie tylko wartości UTM. |
manual_medium | STRING | Medium kampanii ręcznej (utm_medium), które zostało zebrane ze zdarzeniem. Obejmuje też parametry odtworzone z parametrów odesłania, a nie tylko wartości UTM. |
manual_term | STRING | Słowo kluczowe lub hasło kampanii ręcznej (utm_term), które zostało zebrane ze zdarzeniem. |
manual_content | STRING | Dodatkowe metadane kampanii ręcznej (utm_content), które zostały zebrane ze zdarzeniem. |
manual_creative_format | STRING | Format kreacji kampanii ręcznej (utm_creative_format), który został zebrany ze zdarzeniem. |
manual_marketing_tactic | STRING | Taktyka marketingowa kampanii ręcznej (utm_marketing_tactic), która została zebrana ze zdarzeniem. |
manual_source_platform | STRING | Platforma źródłowa kampanii ręcznej (utm_source_platform), która została zebrana ze zdarzeniem. |
gclid | STRING | Identyfikator kliknięcia Google, który został zebrany ze zdarzeniem. |
dclid | STRING | Identyfikator kliknięcia DoubleClick w usługach Display & Video 360 i Campaign Manager 360, który został zebrany ze zdarzeniem. |
srsltid | STRING | Identyfikator konta Google Merchant Center, który został zebrany ze zdarzeniem. |
Rekord session_traffic_source_last_click zawiera dane o źródle wizyt w sesji przypisane na podstawie ostatniego kliknięcia w reklamach Google i kontekstach ręcznych (jeśli są dostępne). |
||
Nazwa pola | Typ danych | Opis |
---|---|---|
session_traffic_source_last_click. manual_campaign.campaign_id | STRING | Identyfikator ostatniej kampanii konfigurowanej ręcznie, w której nastąpiło kliknięcie |
session_traffic_source_last_click. manual_campaign.campaign_name | STRING | Nazwa ostatniej kampanii konfigurowanej ręcznie, w której nastąpiło kliknięcie |
session_traffic_source_last_click. manual_campaign.medium | STRING | Medium ostatniej kampanii konfigurowanej ręcznie, w której nastąpiło kliknięcie (np. płatne wyniki wyszukiwania, bezpłatne wyniki wyszukiwania lub e-mail) |
session_traffic_source_last_click. manual_campaign.term | STRING | Słowo kluczowe lub hasło w ostatniej kampanii konfigurowanej ręcznie, w której nastąpiło kliknięcie |
session_traffic_source_last_click. manual_campaign.content | STRING | Dodatkowe metadane ostatniej kampanii konfigurowanej ręcznie, w której nastąpiło kliknięcie |
session_traffic_source_last_click. manual_campaign.source_platform | STRING | Platforma ostatniej kampanii konfigurowanej ręcznie, w której nastąpiło kliknięcie (np. wyszukiwarka lub media społecznościowe) |
session_traffic_source_last_click. manual_campaign.source | STRING | Konkretne źródło na platformie ostatniej kampanii konfigurowanej ręcznie, w której nastąpiło kliknięcie |
session_traffic_source_last_click. manual_campaign.creative_format | STRING | Format kreacji w ostatniej kampanii konfigurowanej ręcznie, w której nastąpiło kliknięcie |
session_traffic_source_last_click. manual_campaign.marketing_tactic | STRING | Taktyka marketingowa ostatniej kampanii konfigurowanej ręcznie, w której nastąpiło kliknięcie |
session_traffic_source_last_click. google_ads_campaign.customer_id | STRING | Identyfikator klienta powiązany z kontem Google Ads |
session_traffic_source_last_click. google_ads_campaign.account_name | STRING | Nazwa konta Google Ads |
session_traffic_source_last_click. google_ads_campaign.campaign_id | STRING | Identyfikator kampanii Google Ads |
session_traffic_source_last_click. google_ads_campaign.campaign_name | STRING | Nazwa kampanii Google Ads |
session_traffic_source_last_click. google_ads_campaign.ad_group_id | STRING | Identyfikator grupy reklam w kampanii Google Ads |
session_traffic_source_last_click. google_ads_campaign.ad_group_name | STRING | Nazwa grupy reklam w kampanii Google Ads |
Rekord traffic_source zawiera informacje o źródle wizyt, dzięki któremu udało się pozyskać użytkownika. W tabelach danych częściowych rekord ten nie jest wypełniany. Uwaga: wartości w rekordzie traffic_source nie zmieniają się, jeśli po instalacji użytkownik wchodzi w interakcje z kolejnymi kampaniami. |
||
Nazwa pola | Typ danych | Opis |
---|---|---|
traffic_source.name | STRING | Nazwa kampanii marketingowej, dzięki której udało się pozyskać użytkownika. W tabelach częściowych pole to nie jest wypełniane. |
traffic_source.medium | STRING | Nazwa medium (płatne wyniki wyszukiwania, bezpłatne wyniki wyszukiwania, e-mail itp.), dzięki któremu udało się pozyskać użytkownika. W tabelach częściowych pole to nie jest wypełniane. |
traffic_source.source | STRING | Nazwa sieci, dzięki której udało się pozyskać użytkownika. W tabelach danych częściowych pole to nie jest wypełniane. |
Pola stream i platform zawierają informacje o strumieniu i platformie aplikacji. | ||
Nazwa pola | Typ danych | Opis |
---|---|---|
stream_id | STRING | Identyfikator numeryczny strumienia danych, z którego pochodzi zdarzenie. |
platforma | STRING | Platforma strumienia danych (sieć, system iOS lub Android), z której pochodzi zdarzenie. |
Rekord ecommerce zawiera informacje o zdarzeniach e-commerce skonfigurowanych w witrynie lub aplikacji. | ||
Nazwa pola | Typ danych | Opis |
---|---|---|
ecommerce.total_item_quantity | INTEGER | Łączna liczba produktów w ramach tego zdarzenia, która stanowi sumę wartości items.quantity. |
ecommerce.purchase_revenue_in_usd | LICZBA ZMIENNOPRZECINKOWA | Przychody z zakupu w ramach tego zdarzenia wyrażone w dolarach amerykańskich z użyciem jednostki standardowej. Wartość podawana tylko w przypadku zdarzenia purchase. |
ecommerce.purchase_revenue | LICZBA ZMIENNOPRZECINKOWA | Przychody z zakupu w ramach tego zdarzenia wyrażone w walucie lokalnej z użyciem jednostki standardowej. Wartość podawana tylko w przypadku zdarzenia purchase. |
ecommerce.refund_value_in_usd | LICZBA ZMIENNOPRZECINKOWA | Kwota zwrotu środków w ramach tego zdarzenia wyrażona w dolarach amerykańskich z użyciem jednostki standardowej. Wartość podawana tylko w przypadku zdarzenia refund. |
ecommerce.refund_value | LICZBA ZMIENNOPRZECINKOWA | Kwota zwrotu środków w ramach tego zdarzenia wyrażona w walucie lokalnej z użyciem jednostki standardowej. Wartość podawana tylko w przypadku zdarzenia refund. |
ecommerce.shipping_value_in_usd | LICZBA ZMIENNOPRZECINKOWA | Koszt dostawy w ramach tego zdarzenia wyrażony w dolarach amerykańskich z użyciem jednostki standardowej. |
ecommerce.shipping_value | LICZBA ZMIENNOPRZECINKOWA | Koszt dostawy w ramach tego zdarzenia wyrażony w walucie lokalnej. |
ecommerce.tax_value_in_usd | LICZBA ZMIENNOPRZECINKOWA | Wartość podatku w ramach tego zdarzenia wyrażona w dolarach amerykańskich z użyciem jednostki standardowej. |
ecommerce.tax_value | LICZBA ZMIENNOPRZECINKOWA | Wartość podatku w ramach tego zdarzenia wyrażona w walucie lokalnej z użyciem jednostki standardowej. |
ecommerce.transaction_id | STRING | Identyfikator transakcji e-commerce. |
ecommerce.unique_items | INTEGER | Liczba unikalnych produktów w ramach tego zdarzenia ustalona na podstawie wartości atrybutów item_id, item_name i item_brand. |
Rekord items zawiera informacje o produktach uwzględnionych w zdarzeniu. Jest powtarzany w przypadku każdego produktu. | ||
Nazwa pola | Typ danych | Opis |
---|---|---|
items.item_id | STRING | Identyfikator produktu. |
items.item_name | STRING | Nazwa produktu. |
items.item_brand | STRING | Marka produktu. |
items.item_variant | STRING | Wariant produktu. |
items.item_category | STRING | Kategoria produktu. |
items.item_category2 | STRING | Podkategoria produktu. |
items.item_category3 | STRING | Podkategoria produktu. |
items.item_category4 | STRING | Podkategoria produktu. |
items.item_category5 | STRING | Podkategoria produktu. |
items.price_in_usd | LICZBA ZMIENNOPRZECINKOWA | Cena produktu w dolarach amerykańskich podana z użyciem jednostki standardowej. |
items.price | LICZBA ZMIENNOPRZECINKOWA | Cena produktu w walucie lokalnej. |
items.quantity | INTEGER | Liczba sztuk produktu. Jeśli jej nie określisz, domyślną wartością będzie 1. |
items.item_revenue_in_usd | LICZBA ZMIENNOPRZECINKOWA | Przychody z tego produktu obliczone według wzoru: price_in_usd * quantity. Wartość podawana tylko w przypadku zdarzenia purchase w dolarach amerykańskich z użyciem jednostki standardowej. |
items.item_revenue | LICZBA ZMIENNOPRZECINKOWA | Przychody z tego produktu obliczone według wzoru: price * quantity. Wartość podawana tylko w przypadku zdarzenia purchase w walucie lokalnej z użyciem jednostki standardowej. |
items.item_refund_in_usd | LICZBA ZMIENNOPRZECINKOWA | Wartość zwrotu środków za ten produkt obliczona według wzoru: price_in_usd * quantity. Podawana tylko w przypadku zdarzenia refund w dolarach amerykańskich z użyciem jednostki standardowej. |
items.item_refund | LICZBA ZMIENNOPRZECINKOWA | Wartość zwrotu środków za ten produkt obliczona według wzoru: price * quantity. Podawana tylko w przypadku zdarzenia refund w walucie lokalnej z użyciem jednostki standardowej. |
items.coupon | STRING | Kod kuponu zastosowanego do tego produktu. |
items.affiliation | STRING | Powiązanie produktu umożliwiające wskazanie jego dostawcy lub lokalizacji sklepu stacjonarnego. |
items.location_id | STRING | Lokalizacja powiązana z produktem. |
items.item_list_id | STRING | Identyfikator listy, na której produkt został przedstawiony użytkownikowi. |
items.item_list_name | STRING | Nazwa listy, na której produkt został przedstawiony użytkownikowi. |
Items.item_list_index | STRING | Pozycja produktu na liście. |
items.promotion_id | STRING | Identyfikator promocji produktu. |
items.promotion_name | STRING | Nazwa promocji produktu. |
items.creative_name | STRING | Nazwa kreacji użytej w spocie promocyjnym. |
items.creative_slot | STRING | Nazwa boksu kreacji. |
Rekord item_params
Rekord item_params przechowuje zdefiniowane przez Ciebie niestandardowe parametry produktu. Pamiętaj, że wstępnie zdefiniowane parametry produktu, takie jak item_id czy item_name, nie są tutaj uwzględnione. Zamiast tego są eksportowane jako pola jawne. Zestaw parametrów zapisanych w rekordzie item_params jest unikalny dla każdej implementacji. Więcej informacji o implementacjach e-commerce i tablicy items Google Analytics 4 znajdziesz w artykule Pomiar e-commerce. |
||
Nazwa pola | Typ danych | Opis |
---|---|---|
items.item_params.key | STRING | Nazwa parametru produktu. |
items.item_params.value | RECORD | Rekord zawierający wartość parametru produktu. |
items.item_params.value.string_value | STRING | Jeśli parametr produktu jest ciągiem znaków, zostaje wypełniony w tym polu. |
items.item_params.value.int_value | INTEGER | Jeśli parametr produktu jest liczbą całkowitą, zostaje wypełniony w tym polu. |
items.item_params.value.double_value | LICZBA ZMIENNOPRZECINKOWA | Jeśli parametr produktu jest wartością podwójnej precyzji, zostaje wypełniony w tym polu. |
items.item_params.value.float_value | LICZBA ZMIENNOPRZECINKOWA | Jeśli parametr produktu jest liczbą zmiennoprzecinkową, zostaje wypełniony w tym polu. |
Rekord wydawca zawiera informacje o zdarzeniach pochodzących z integracji z wydawcą związanych z wyświetlaniem reklam, czyli z AdMob. | ||
Nazwa pola | Typ danych | Opis |
---|---|---|
wydawca | RECORD | Rekord danych wydawcy pochodzących z AdMob. |
publisher.ad_revenue_in_usd | LICZBA ZMIENNOPRZECINKOWA | Szacunkowe przychody z reklam uzyskane dzięki temu zdarzeniu wyrażone w dolarach amerykańskich. Wartość podawana tylko w przypadku zdarzeń wyświetleń reklam. |
publisher.ad_format | STRING | Określa sposób wyświetlania reklam i ich umiejscowienie. Typowe formaty to: „Reklama pełnoekranowa”, „Baner”, „Reklama z nagrodą” i „Zaawansowana reklama natywna”. |
publisher.ad_source_name | STRING | Źródłowa sieć, która wyświetliła reklamę. Typowe źródła to „Sieć AdMob”, „Meta Audience Network” i „Zapośredniczone autoreklamy”. |
publisher.ad_unit_id | STRING | Nazwa wybrana przez Ciebie do opisu tej jednostki reklamowej. Jednostki reklamowe to kontenery, które umieszczasz w aplikacjach, aby wyświetlać użytkownikom reklamy. |
Wiersze
Dane o pojedynczym zdarzeniu mogą być widoczne w jednym wierszu lub w większej ich liczbie w zależności od tego, czy zawiera ono powtarzające się rekordy. Na przykład zdarzenie page_view
z większą liczbą parametrów event_params
wyglądałoby podobnie do tabeli poniżej. Początkowy wiersz zawiera nazwę zdarzenia, datę, sygnaturę czasową i inne niepowtarzalne elementy danych. Rekord event_params
jest powtarzany w przypadku każdego parametru powiązanego ze zdarzeniem. Te powtarzające się rekordy są wypełniane w kolejnych wierszach bezpośrednio pod początkowym wierszem zdarzenia.
event_date | event_timestamp | event_name | event_params.key | event_params_value.string_value |
---|---|---|---|---|
20220222 | 1643673600483790 | page_view | page_location | https://example.com |
page_title | Strona główna | |||
przeciętny | odesłanie | |||
źródło | ||||
page_referrer | https://www.google.com | |||
<parameters...> | <wartości…> |
Te dane o zdarzeniu wyświetlają się w interfejsie GA4 w ten sposób.
Jeśli używasz starszych wersji pakietu SDK i planujesz jego uaktualnienie na Androidzie do wersji 17.2.5 (lub nowszej) lub na iOS do wersji 16.20.0 (lub nowszej), pamiętaj o tych kwestiach:
- Aby korzystać z bieżącego schematu BigQuery Export, musisz uaktualnić swój pakiet SDK na Androida do wersji 17.2.5 (lub nowszej) lub na iOS do wersji 16.20.0 (lub nowszej). Jeśli używasz starszych wersji pakietu SDK, wyeksportowane dane będą zgodne ze starym schematem.
- Po uaktualnieniu będziesz mieć dostęp do danych produktów tylko w tablicy powtórzonych produktów. Dane produktów nie będą już dostępne w standardowych parametrach zdarzeń, jak miało to miejsce w przypadku starszych wersji pakietu SDK.
- Ta zmiana została wprowadzona, by umożliwić analizę wielu produktów.
- Dlatego może być konieczne dostosowanie odwołań do danych o produktach.
- Zaloguj się na stronie konsoli Cloud Platform > Zarządzaj zasobami.
- Otwórz projekt, którego dane chcesz przenieść, i u góry strony kliknij Aktywuj Google Cloud Shell.
- Gdy powłoka się otworzy, skopiuj ten skrypt do pliku
migration_script.sql
:- Wykonaj polecenie
cat > migration_script.sql
- Skopiuj poniższy skrypt i wklej go do powłoki.
- Aby zapisać zmiany i zamknąć powłokę, naciśnij Ctrl+D.
SELECT @date AS event_date, event.timestamp_micros AS event_timestamp, event.previous_timestamp_micros AS event_previous_timestamp, event.name AS event_name, event.value_in_usd AS event_value_in_usd, user_dim.bundle_info.bundle_sequence_id AS event_bundle_sequence_id, user_dim.bundle_info.server_timestamp_offset_micros as event_server_timestamp_offset, ( SELECT ARRAY_AGG(STRUCT(event_param.key AS key, STRUCT(event_param.value.string_value AS string_value, event_param.value.int_value AS int_value, event_param.value.double_value AS double_value, event_param.value.float_value AS float_value) AS value)) FROM UNNEST(event.params) AS event_param) AS event_params, user_dim.first_open_timestamp_micros AS user_first_touch_timestamp, user_dim.user_id AS user_id, user_dim.app_info.app_instance_id AS user_pseudo_id, "" AS stream_id, user_dim.app_info.app_platform AS platform, STRUCT( user_dim.ltv_info.revenue AS revenue, user_dim.ltv_info.currency AS currency ) AS user_ltv, STRUCT( user_dim.traffic_source.user_acquired_campaign AS name, user_dim.traffic_source.user_acquired_medium AS medium, user_dim.traffic_source.user_acquired_source AS source ) AS traffic_source, STRUCT( user_dim.geo_info.continent AS continent, user_dim.geo_info.country AS country, user_dim.geo_info.region AS region, user_dim.geo_info.city AS city ) AS geo, STRUCT( user_dim.device_info.device_category AS category, user_dim.device_info.mobile_brand_name, user_dim.device_info.mobile_model_name, user_dim.device_info.mobile_marketing_name, user_dim.device_info.device_model AS mobile_os_hardware_model, @platform AS operating_system, user_dim.device_info.platform_version AS operating_system_version, user_dim.device_info.device_id AS vendor_id, user_dim.device_info.resettable_device_id AS advertising_id, user_dim.device_info.user_default_language AS language, user_dim.device_info.device_time_zone_offset_seconds AS time_zone_offset_seconds, IF(user_dim.device_info.limited_ad_tracking, "Yes", "No") AS is_limited_ad_tracking ) AS device, STRUCT( user_dim.app_info.app_id AS id, @firebase_app_id AS firebase_app_id, user_dim.app_info.app_version AS version, user_dim.app_info.app_store AS install_source ) AS app_info, ( SELECT ARRAY_AGG(STRUCT(user_property.key AS key, STRUCT(user_property.value.value.string_value AS string_value, user_property.value.value.int_value AS int_value, user_property.value.value.double_value AS double_value, user_property.value.value.float_value AS float_value, user_property.value.set_timestamp_usec AS set_timestamp_micros ) AS value)) FROM UNNEST(user_dim.user_properties) AS user_property) AS user_properties FROM `SCRIPT_GENERATED_TABLE_NAME`, UNNEST(event_dim) AS event
- Wykonaj polecenie
- Otwórz nową powłokę i skopiuj ten skrypt do pliku
migration.sh
:- Wykonaj polecenie
cat > migration.sh
- Skopiuj poniższy skrypt i wklej go do powłoki.
- Naciśnij Ctrl+D, by zapisać zmiany i zamknąć powłokę.
Zmodyfikuj widoczny poniżej skrypt, aby uwzględnić identyfikator usługi Analytics, identyfikator projektu BigQuery, identyfikator aplikacji Firebase, nazwę zbioru danych BigQuery oraz daty rozpoczęcia i zakończenia okresu, w którego przypadku chcesz uruchomić migrację danych.Skrypt (migration.sh):# Identyfikator usługi Analytics dla projektu. Znajdziesz go w Ustawieniach Analytics w Firebase. PROPERTY_ID=identyfikator Twojej usługi Analytics # Eksportowany projekt BigQuery. BQ_PROJECT_ID="identyfikator Twojego projektu BigQuery" (np. "firebase-public-project") # Identyfikator Firebase danej aplikacji. FIREBASE_APP_ID="identyfikator Firebase Twojej aplikacji" (np. "1:300830567303:ios:09b1ab1d3ca29bda") # Zbiór danych, z którego importujesz informacje. BQ_DATASET="nazwa zestawu BigQuery, z którego chcesz importować dane" (np. "com_firebase_demo_IOS") # Platform PLATFORM="platform of the app. ANDROID or IOS" # Date range for which you want to run migration, [START_DATE,END_DATE] inclusive. START_DATE=20180324 END_DATE=20180327 # Nie zmieniaj poniższego skryptu, jeśli nie masz odpowiednich kwalifikacji :) startdate=$(date -d"$START_DATE" +%Y%m%d) || exit -1 enddate=$(date -d"$END_DATE" +%Y%m%d) || exit -1 # Powtarzaj dla kolejnych dat. DATE="$startdate" while [ "$DATE" -le "$enddate" ]; do # Tabela BQ stworzona z powyższych parametrów. BQ_TABLE="$BQ_PROJECT_ID.$BQ_DATASET.app_events_$DATE" echo "Migrating $BQ_TABLE" cat migration_script.sql | sed -e "s/SCRIPT_GENERATED_TABLE_NAME/$BQ_TABLE/g" | bq query \ --debug_mode \ --allow_large_results \ --noflatten_results \ --use_legacy_sql=False \ --destination_table analytics_$PROPERTY_ID.events_$DATE \ --batch \ --append_table \ --parameter=firebase_app_id::$FIREBASE_APP_ID \ --parameter=date::$DATE \ --parameter=platform::$PLATFORM \ --project_id=$BQ_PROJECT_ID temp=$(date -I -d "$DATE + 1 day") DATE=$(date -d "$temp" +%Y%m%d) done exit # KONIEC SKRYPTU
- Wykonaj polecenie
- Otwórz nową powłokę i wykonaj polecenie
bash migration.sh
user_dim
Nazwa pola | Typ danych | Opis |
---|---|---|
user_dim | RECORD | Rekord z wymiarami dotyczącymi użytkownika. |
user_dim.user_id | STRING | Identyfikator użytkownika ustawiony poprzez polecenie interfejsu API setUserId. |
user_dim.first_open_timestamp_micros | INTEGER | Czas pierwszego otwarcia aplikacji (w mikrosekundach). |
user_dim.user_properties | RECORD | Powtarzający się rekord właściwości użytkownika ustawionych poprzez polecenie interfejsu API setUserProperty. |
user_dim.user_properties.key | STRING | Nazwa właściwości użytkownika. |
user_dim.user_properties.value | RECORD | Rekord z informacjami o właściwości użytkownika. |
user_dim.user_properties.value.value | RECORD | Rekord z wartością właściwości użytkownika. |
user_dim.user_properties.value.value.string_value | STRING | Wartość ciągu przypisana do właściwości użytkownika. |
user_dim.user_properties.value.value.int_value | INTEGER | Wartość liczby całkowitej przypisana do właściwości użytkownika. |
user_dim.user_properties.value.value.double_value | LICZBA ZMIENNOPRZECINKOWA | Wartość podwójnej precyzji przypisana do właściwości użytkownika. |
user_dim.user_properties.value.set_timestamp_usec | INTEGER | Czas ostatniego ustawienia właściwości użytkownika (w mikrosekundach). |
user_dim.user_properties.value.index | INTEGER | Indeks (0–24) właściwości użytkownika. |
user_dim.device_info | RECORD | Rekord z informacjami o urządzeniu. |
user_dim.device_info.device_category | STRING | Kategoria urządzenia (komórka, tablet lub komputer). |
user_dim.device_info.mobile_brand_name | STRING | Marka urządzenia. |
user_dim.device_info.mobile_model_name | STRING | Nazwa modelu urządzenia. |
user_dim.device_info.mobile_marketing_name | STRING | Nazwa marketingowa urządzenia. |
user_dim.device_info.device_model | STRING | Model urządzenia. |
user_dim.device_info.platform_version | STRING | Wersja systemu operacyjnego. |
user_dim.device_info.device_id | STRING | IDFV (tylko gdy identyfikator IDFA jest niedostępny). |
user_dim.device_info.resettable_device_id | STRING | Identyfikator wyświetlania reklam / IDFA. |
user_dim.device_info.user_default_language | STRING | Język systemu operacyjnego. |
user_dim.device_info.device_time_zone_offset_seconds | INTEGER | Przesunięcie w stosunku do strefy czasowej GMT (w sekundach). |
user_dim.device_info.limited_ad_tracking | WARTOŚĆ LOGICZNA | Ustawienie ograniczenia śledzenia reklam na urządzeniu. |
user_dim.geo_info | RECORD | Rekord z danymi geograficznymi użytkownika. |
user_dim.geo_info.continent | STRING | Kontynent, z którego zostały zgłoszone zdarzenia, określony na podstawie adresu IP. |
user_dim.geo_info.country | STRING | Kraj, z którego zostały zgłoszone zdarzenia, określony na podstawie adresu IP. |
user_dim.geo_info.region | STRING | Region, z którego zostały zgłoszone zdarzenia, określony na podstawie adresu IP. |
user_dim.geo_info.city | STRING | Miasto, z którego zostały zgłoszone zdarzenia, określone na podstawie adresu IP. |
user_dim.app_info | RECORD | Rekord z informacjami o aplikacji. |
user_dim.app_info.app_version | STRING | Wartość parametru versionName (Android) lub skrócona wersja pakietu. |
user_dim.app_info.app_instance_id | STRING | Unikalny identyfikator tej instancji aplikacji. |
user_dim.app_info.app_store | STRING | Sklep, z którego zainstalowano aplikację. |
user_dim.app_info.app_platform | STRING | Platforma, na której działa aplikacja. |
user_dim.traffic_source | RECORD | Nazwa źródła wizyt wykorzystanego do pozyskania użytkownika. W tabelach częściowych to pole nie jest wypełniane. |
user_dim.traffic_source.user_acquired_campaign | STRING | Nazwa kampanii marketingowej, w której pozyskano użytkownika. W tabelach częściowych to pole nie jest wypełniane. |
user_dim.traffic_source.user_acquired_medium | STRING | Nazwa medium (płatne wyniki wyszukiwania, bezpłatne wyniki wyszukiwania, e-mail itp.), dzięki któremu pozyskano użytkownika. W tabelach częściowych pole to nie jest wypełniane. |
user_dim.traffic_source.user_acquired_source | STRING | Nazwa sieci, dzięki której pozyskano użytkownika. W tabelach częściowych to pole nie jest wypełniane. |
user_dim.bundle_info | RECORD | Rekord z informacjami o zestawie, w którym zostały przesłane te zdarzenia. |
user_dim.bundle_info.bundle_sequence_id | INTEGER | Identyfikator sekwencyjny zestawu, w którym zostały przesłane te zdarzenia. |
user_dim.ltv_info | RECORD | Rekord z informacjami o użytkowniku dotyczącymi wartości od początku śledzenia. W tabelach częściowych to pole nie jest wypełniane. |
user_dim.ltv_info.revenue | LICZBA ZMIENNOPRZECINKOWA | Wartość użytkownika od początku śledzenia (przychód). W tabelach częściowych to pole nie jest wypełniane. |
user_dim.ltv_info.currency | STRING | Wartość użytkownika od początku śledzenia (waluta). W tabelach częściowych to pole nie jest wypełniane. |
event_dim
Nazwa pola | Typ danych | Opis |
---|---|---|
event_dim | RECORD | Powtarzający się rekord z informacjami dotyczącymi zdarzeń w tym zestawie. |
event_dim.date | STRING | Data rejestracji zdarzenia (w formacie RRRRMMDD i w strefie czasowej aplikacji). |
event_dim.name | STRING | Nazwa zdarzenia. |
event_dim.params | RECORD | Powtarzający się rekord z parametrami powiązanymi z tym zdarzeniem. |
event_dim.params.key | STRING | Klucz parametru zdarzenia. |
event_dim.params.value | RECORD | Rekord z wartością parametru zdarzenia. |
event_dim.params.value.string_value | STRING | Wartość ciągu przypisana do parametru zdarzenia. |
event_dim.params.value.int_value | INTEGER | Wartość liczby całkowitej przypisana do parametru zdarzenia. |
event_dim.params.value.double_value | LICZBA ZMIENNOPRZECINKOWA | Wartość podwójnej precyzji przypisana do parametru zdarzenia. |
event_dim.timestamp_micros | INTEGER | Czas zarejestrowania tego zdarzenia przez klienta (w mikrosekundach, UTC). |
event_dim.previous_timestamp_micros | INTEGER | Czas poprzedniego zarejestrowania tego zdarzenia przez klienta (w mikrosekundach, UTC). |