Google Merchant Center top products
Overview
Best sellers data helps merchants understand the most popular brands and products in Shopping ads. For more information about best sellers, see the description in Supported Reports.
The data is written to a table named BestSellers_TopProducts_MERCHANT_ID
if you are using an individual Merchant ID, or
BestSellers_TopProducts_AGGREGATOR_ID
if you're using an MCA account.
Schema
The BestSellers_TopProducts_
table has the following schema:
Column | BigQuery data type | Description | Sample field |
---|---|---|---|
rank_timestamp |
TIMESTAMP |
Date and time when the rank was published. | 2020-03-14 00:00:00 UTC |
rank_id |
STRING |
Rank identifier to join against the Product Inventory table. | 2020-03-14:AU:100:2:product |
rank |
INTEGER |
The popularity rank of the product on Shopping ads for the `ranking_country` and `ranking_category`. Popularity is based on the estimated number of products sold. The rank updates daily. The data included in metrics might be delayed by up 2 days. | 2 |
previous_rank |
INTEGER |
The change in rank over the previous 7 days. | 4 |
ranking_country |
STRING |
Country code used for ranking. | AU |
ranking_category |
INTEGER |
Google product category ID used for ranking. | 5181 |
ranking_category_path |
RECORD, |
Google product category full path for each locale used for ranking. | |
ranking_category_path.locale |
STRING |
en-AU | |
ranking_category_path.name |
STRING |
Luggage & Bags | |
relative_demand |
RECORD |
A product's estimated demand in relation to the product with the highest popularity rank in the same category and country. | |
relative_demand.bucket |
STRING |
Very high | |
relative_demand.min |
INTEGER |
51 | |
relative_demand.max |
INTEGER |
100 | |
previous_relative_demand |
RECORD |
A product's estimated demand in relation to the product with the highest popularity rank in the same category and country over the previous 7 days. | |
previous_relative_demand.bucket |
STRING |
Very high | |
previous_relative_demand.min |
INTEGER |
51 | |
previous_relative_demand.max |
INTEGER |
100 | |
product_title |
RECORD, |
Product title. | |
product_title.locale |
STRING |
en-AU | |
product_title.name |
STRING |
ExampleBrand Backpack | |
gtins |
STRING, |
Global Trade Item Number (GTIN). | 07392158680955 |
brand |
STRING |
Brand of the item. | ExampleBrand |
google_brand_id |
STRING |
Google brand ID of the item. | 11887454107284768328 |
google_product_category |
INTEGER |
Google product category ID of the item. | 100 |
google_product_category_path |
RECORD, |
Google product category full path of the item. | |
google_product_category_path.locale |
STRING |
en-US | |
google_product_category_path.name |
STRING |
Luggage & Bags > Backpacks | |
price_range |
RECORD |
Price range: lower and upper (with no decimals) and currency. The price does not include shipping costs. | n/a |
price_range.min |
NUMERIC |
115 | |
price_range.max |
NUMERIC |
147 | |
price_range.currency |
STRING |
AUD |
Understanding the data
- Ranking categories are subject to change over time.
- The Google product category
in the
BestSellers_TopProducts_Inventory_
table might be different from the Google Product Category in theProducts_
table. TheProducts_
table surfaces a retailer provided value of Google product category. - For products in your inventory, the price range in
BestSellers_TopProducts_
might differ from theProducts_PriceBenchmarks_
table. Price benchmarks metrics are calculated over a different time period. The price ranges inBestSellers_TopProducts_
reflect prices of different variants of the product, whereas the price ranges inProducts_PriceBenchmarks_
only refer to a single variant. - Some products in your inventory might not have a rank for each category in the path. We limit the number of products per category to 10,000, and in some sub-categories we don't publish any ranking.
Example
Products might have a rank for each category within the product category
path. For example, a Google Pixel 4 phone is classified as Electronics >
Communications > Telephony > Mobile Phones
. The Pixel 4 will have a separate
ranking for Electronics, Communications, Telephony, and Mobile Phones. Use
ranking_category_path
in addition to ranking_country
to determine the depth
of category that you want to see a ranking for.
In the example below, an ExampleBrand Backpack contains a separate ranking for both the Luggage & Bags and Backpacks categories. Select "Backpacks" and "AU" to see what its ranking is in Australia in the Backpacks category.
Ranking for Luggage & Bags
product_title | ExampleBrand Backpack |
---|---|
ranking_country | AU |
ranking_category | 5181 |
ranking_category_path | Luggage & Bags |
Rank | 40 |
google_product_category | 100 |
google_product_category_path | Luggage & Bags > Backpacks |
Ranking for Luggage & Bags > Backpacks
product_title | ExampleBrand Backpack |
---|---|
ranking_country | AU |
ranking_category | 100 |
ranking_category_path | Luggage & Bags > Backpacks |
rank | 4 |
google_product_category | 100 |
google_product_category_path | Luggage & Bags > Backpacks |
Query examples
Top products for a given category and country
The following SQL query returns top products for the Smartphones
category in
the US.
SELECT rank, previous_rank, relative_demand.bucket, (SELECT name FROM top_products.product_title WHERE locale = 'en-US') AS product_title, brand, price_range FROM dataset.BestSellers_TopProducts_merchant_id AS top_products WHERE _PARTITIONDATE = 'YYYY-MM-DD' AND ranking_category = 267 /*Smartphones*/ AND ranking_country = 'US' ORDER BY rank
Top products in your inventory
The following SQL query joins BestSellers_TopProducts_Inventory_
and
BestSellers_TopProducts_
data to return a list of top products you
have in your inventory.
WITH latest_top_products AS ( SELECT * FROM dataset.BestSellers_TopProducts_merchant_id WHERE _PARTITIONDATE = 'YYYY-MM-DD' ), latest_top_products_inventory AS ( SELECT * FROM dataset.BestSellers_TopProducts_Inventory_merchant_id WHERE _PARTITIONDATE = 'YYYY-MM-DD' ) SELECT top_products.rank, inventory.product_id, (SELECT ANY_VALUE(name) FROM top_products.product_title) AS product_title, top_products.brand, top_products.gtins FROM latest_top_products AS top_products INNER JOIN latest_top_products_inventory AS inventory USING (rank_id)