Last active
September 6, 2024 14:57
-
-
Save siakaramalegos/752b83284b3a4817f905cb17c0e4e8ce to your computer and use it in GitHub Desktop.
CrUX/HTTPArchive query for aggregated performance by Shopify theme (sampled)
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# Shopify themes passing core web vitals | |
CREATE TEMP FUNCTION IS_GOOD (good FLOAT64, needs_improvement FLOAT64, poor FLOAT64) RETURNS BOOL AS ( | |
good / (good + needs_improvement + poor) >= 0.75 | |
); | |
CREATE TEMP FUNCTION IS_POOR (good FLOAT64, needs_improvement FLOAT64, poor FLOAT64) RETURNS BOOL AS ( | |
poor / (good + needs_improvement + poor) > 0.25 | |
); | |
CREATE TEMP FUNCTION IS_NON_ZERO (good FLOAT64, needs_improvement FLOAT64, poor FLOAT64) RETURNS BOOL AS ( | |
good + needs_improvement + poor > 0 | |
); | |
WITH archive_pages AS ( | |
SELECT | |
client, | |
page AS url, | |
JSON_VALUE(custom_metrics, '$.ecommerce.Shopify.theme.name') AS theme_name, | |
JSON_VALUE(custom_metrics, '$.ecommerce.Shopify.theme.theme_store_id') AS theme_store_id, | |
-- row_number() over (partition by page order by qty desc) as rn | |
-- FROM `httparchive.all.pages` TABLESAMPLE SYSTEM (0.05 PERCENT) | |
FROM `httparchive-bigquery-316519._d6e68ddfa7b6887fe2c9264d97e893d71ae496c7.anondc72b7f0_34f0_42f6_9c1f_dbc22475223d` | |
WHERE | |
date = '2024-07-01'AND | |
is_root_page AND | |
JSON_VALUE(custom_metrics, '$.ecommerce.Shopify.theme.name') IS NOT NULL --first grab all shop for market share | |
) | |
SELECT | |
client, | |
archive_pages.theme_store_id AS id, | |
theme_names.theme_name AS top_theme_name, | |
COUNT(DISTINCT origin) AS origins, | |
# Origins with good LCP divided by origins with any LCP. | |
SAFE_DIVIDE( | |
COUNT(DISTINCT IF(IS_GOOD(fast_lcp, avg_lcp, slow_lcp), origin, NULL)), | |
COUNT(DISTINCT IF(IS_NON_ZERO(fast_lcp, avg_lcp, slow_lcp), origin, NULL))) AS pct_good_lcp, | |
# Origins with needs improvement are anything not good, nor poor. | |
1 - | |
SAFE_DIVIDE( | |
COUNT(DISTINCT IF(IS_GOOD(fast_lcp, avg_lcp, slow_lcp), origin, NULL)), | |
COUNT(DISTINCT IF(IS_NON_ZERO(fast_lcp, avg_lcp, slow_lcp), origin, NULL))) | |
- | |
SAFE_DIVIDE( | |
COUNT(DISTINCT IF(IS_POOR(fast_lcp, avg_lcp, slow_lcp), origin, NULL)), | |
COUNT(DISTINCT IF(IS_NON_ZERO(fast_lcp, avg_lcp, slow_lcp), origin, NULL))) | |
AS pct_ni_lcp, | |
# Origins with poor LCP divided by origins with any LCP. | |
SAFE_DIVIDE( | |
COUNT(DISTINCT IF(IS_POOR(fast_lcp, avg_lcp, slow_lcp), origin, NULL)), | |
COUNT(DISTINCT IF(IS_NON_ZERO(fast_lcp, avg_lcp, slow_lcp), origin, NULL))) AS pct_poor_lcp, | |
# Origins with good TTFB divided by origins with any TTFB. | |
SAFE_DIVIDE( | |
COUNT(DISTINCT IF(IS_GOOD(fast_ttfb, avg_ttfb, slow_ttfb), origin, NULL)), | |
COUNT(DISTINCT IF(IS_NON_ZERO(fast_ttfb, avg_ttfb, slow_ttfb), origin, NULL))) AS pct_good_ttfb, | |
# Origins with needs improvement are anything not good, nor poor. | |
1 - | |
SAFE_DIVIDE( | |
COUNT(DISTINCT IF(IS_GOOD(fast_ttfb, avg_ttfb, slow_ttfb), origin, NULL)), | |
COUNT(DISTINCT IF(IS_NON_ZERO(fast_ttfb, avg_ttfb, slow_ttfb), origin, NULL))) | |
- | |
SAFE_DIVIDE( | |
COUNT(DISTINCT IF(IS_POOR(fast_ttfb, avg_ttfb, slow_ttfb), origin, NULL)), | |
COUNT(DISTINCT IF(IS_NON_ZERO(fast_ttfb, avg_ttfb, slow_ttfb), origin, NULL))) | |
AS pct_ni_ttfb, | |
# Origins with poor TTFB divided by origins with any TTFB. | |
SAFE_DIVIDE( | |
COUNT(DISTINCT IF(IS_POOR(fast_ttfb, avg_ttfb, slow_ttfb), origin, NULL)), | |
COUNT(DISTINCT IF(IS_NON_ZERO(fast_ttfb, avg_ttfb, slow_ttfb), origin, NULL))) AS pct_poor_ttfb, | |
# Origins with good FCP divided by origins with any FCP. | |
SAFE_DIVIDE( | |
COUNT(DISTINCT IF(IS_GOOD(fast_fcp, avg_fcp, slow_fcp), origin, NULL)), | |
COUNT(DISTINCT IF(IS_NON_ZERO(fast_fcp, avg_fcp, slow_fcp), origin, NULL))) AS pct_good_fcp, | |
# Origins with needs improvement are anything not good, nor poor. | |
1 - | |
SAFE_DIVIDE( | |
COUNT(DISTINCT IF(IS_GOOD(fast_fcp, avg_fcp, slow_fcp), origin, NULL)), | |
COUNT(DISTINCT IF(IS_NON_ZERO(fast_fcp, avg_fcp, slow_fcp), origin, NULL))) | |
- | |
SAFE_DIVIDE( | |
COUNT(DISTINCT IF(IS_POOR(fast_fcp, avg_fcp, slow_fcp), origin, NULL)), | |
COUNT(DISTINCT IF(IS_NON_ZERO(fast_fcp, avg_fcp, slow_fcp), origin, NULL))) | |
AS pct_ni_fcp, | |
# Origins with poor FCP divided by origins with any FCP. | |
SAFE_DIVIDE( | |
COUNT(DISTINCT IF(IS_POOR(fast_fcp, avg_fcp, slow_fcp), origin, NULL)), | |
COUNT(DISTINCT IF(IS_NON_ZERO(fast_fcp, avg_fcp, slow_fcp), origin, NULL))) AS pct_poor_fcp, | |
# Origins with good INP divided by origins with any INP. | |
SAFE_DIVIDE( | |
COUNT(DISTINCT IF(IS_GOOD(fast_inp, avg_inp, slow_inp), origin, NULL)), | |
COUNT(DISTINCT IF(IS_NON_ZERO(fast_inp, avg_inp, slow_inp), origin, NULL))) AS pct_good_inp, | |
# Origins with needs improvement are anything not good, nor poor. | |
1 - | |
SAFE_DIVIDE( | |
COUNT(DISTINCT IF(IS_GOOD(fast_inp, avg_inp, slow_inp), origin, NULL)), | |
COUNT(DISTINCT IF(IS_NON_ZERO(fast_inp, avg_inp, slow_inp), origin, NULL))) | |
- | |
SAFE_DIVIDE( | |
COUNT(DISTINCT IF(IS_POOR(fast_inp, avg_inp, slow_inp), origin, NULL)), | |
COUNT(DISTINCT IF(IS_NON_ZERO(fast_inp, avg_inp, slow_inp), origin, NULL))) | |
AS pct_ni_inp, | |
# Origins with poor INP divided by origins with any INP. | |
SAFE_DIVIDE( | |
COUNT(DISTINCT IF(IS_POOR(fast_inp, avg_inp, slow_inp), origin, NULL)), | |
COUNT(DISTINCT IF(IS_NON_ZERO(fast_inp, avg_inp, slow_inp), origin, NULL))) AS pct_poor_inp, | |
# Origins with good CLS divided by origins with any CLS. | |
SAFE_DIVIDE( | |
COUNT(DISTINCT IF(IS_GOOD(small_cls, medium_cls, large_cls), origin, NULL)), | |
COUNT(DISTINCT IF(IS_NON_ZERO(small_cls, medium_cls, large_cls), origin, NULL))) AS pct_good_cls, | |
# Origins with needs improvement are anything not good, nor poor. | |
1 - | |
SAFE_DIVIDE( | |
COUNT(DISTINCT IF(IS_GOOD(small_cls, medium_cls, large_cls), origin, NULL)), | |
COUNT(DISTINCT IF(IS_NON_ZERO(small_cls, medium_cls, large_cls), origin, NULL))) | |
- | |
SAFE_DIVIDE( | |
COUNT(DISTINCT IF(IS_POOR(small_cls, medium_cls, large_cls), origin, NULL)), | |
COUNT(DISTINCT IF(IS_NON_ZERO(small_cls, medium_cls, large_cls), origin, NULL))) | |
AS pct_ni_cls, | |
# Origins with poor CLS divided by origins with any CLS. | |
SAFE_DIVIDE( | |
COUNT(DISTINCT IF(IS_POOR(small_cls, medium_cls, large_cls), origin, NULL)), | |
COUNT(DISTINCT IF(IS_NON_ZERO(small_cls, medium_cls, large_cls), origin, NULL))) AS pct_poor_cls, | |
# Origins with good LCP, INP (optional), and CLS divided by origins with any LCP and CLS. | |
SAFE_DIVIDE( | |
COUNT(DISTINCT IF( | |
IS_GOOD(fast_lcp, avg_lcp, slow_lcp) AND | |
IS_GOOD(fast_inp, avg_inp, slow_inp) IS NOT FALSE AND | |
IS_GOOD(small_cls, medium_cls, large_cls), origin, NULL)), | |
COUNT(DISTINCT IF( | |
IS_NON_ZERO(fast_lcp, avg_lcp, slow_lcp) AND | |
IS_NON_ZERO(small_cls, medium_cls, large_cls), origin, NULL))) AS pct_good_cwv | |
FROM | |
`chrome-ux-report.materialized.device_summary` | |
JOIN archive_pages | |
ON | |
CONCAT(origin, '/') = url AND | |
IF(device = 'desktop', 'desktop', 'mobile') = client | |
JOIN ( | |
SELECT | |
COUNT(DISTINCT url) as pages_count, | |
theme_store_id, | |
theme_name, | |
row_number() over (partition by theme_store_id order by COUNT(DISTINCT url) desc) as rank | |
FROM archive_pages | |
GROUP BY | |
theme_store_id, | |
theme_name | |
ORDER BY COUNT(DISTINCT url) DESC | |
) theme_names | |
ON IFNULL(theme_names.theme_store_id, 'N/A') = IFNULL(archive_pages.theme_store_id, 'N/A') | |
WHERE | |
date = '2024-07-01' AND | |
theme_names.rank = 1 | |
GROUP BY | |
client, | |
id, | |
top_theme_name | |
ORDER BY | |
origins DESC |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment