Introduction
Google Analytics 4 (GA4) is a powerhouse, offering profound insights into user behavior and website performance. To harness GA4’s full potential, mastery of SQL queries is indispensable. In this blog post, we unravel the intricacies of user interactions on landing pages, offering a detailed GA4 Landing Page Report using BigQuery.
The provided code dives into metrics such as screen page views, sessions, engaged sessions, total users, bounce rate, and average engagement time per user. Join us as we dissect the code, providing insights into user behavior, optimizing landing pages, and enhancing overall digital experiences using GA4 Landing Page Report.
The SQL queries provided in this blog post are tailored for execution in BigQuery, Google’s enterprise data warehouse. BigQuery is a cloud-based platform designed for fast and efficient analysis of large datasets.This post is an invitation to wield GA4 and SQL queries as precision instruments, transforming raw data into actionable intelligence for digital success. Happy querying!
The SQL Query:
SELECT
landing_page,
SUM(screen_page_views) AS screen_page_views,
COUNT(DISTINCT session_id) AS sessions,
SUM(CAST(engaged_sessions AS INT)) AS engaged_sessions,
COUNT(DISTINCT user_pseudo_id) AS total_users,
1 - SAFE_DIVIDE(
SUM(CAST(engaged_sessions AS INT)),
COUNT(DISTINCT session_id)
) AS bounce_rate,
SAFE_DIVIDE(
SUM(engagement_time_seconds),
COUNT(DISTINCT user_pseudo_id)
) AS average_engagement_time_per_user
FROM
(
SELECT
MAX(
(
SELECT
value.string_value
FROM
UNNEST (event_params)
WHERE
event_name = 'session_start'
AND key = 'page_location'
)
) AS landing_page,
COUNT(
CASE
WHEN event_name = 'page_view' THEN 1
END
) AS screen_page_views,
CONCAT(
user_pseudo_id,
(
SELECT
value.int_value
FROM
UNNEST (event_params)
WHERE
key = 'ga_session_id'
)
) AS session_id,
MAX(
(
SELECT
value.string_value
FROM
UNNEST (event_params)
WHERE
key = 'session_engaged'
)
) AS engaged_sessions,
user_pseudo_id,
SAFE_DIVIDE(
SUM(
(
SELECT
value.int_value
FROM
UNNEST (event_params)
WHERE
key = 'engagement_time_msec'
)
),
1000
) AS engagement_time_seconds
FROM
`add_yor_dataset_name_here_202310*`
WHERE
event_date BETWEEN '20231001' AND '20231031'
GROUP BY
session_id,
user_pseudo_id
)
GROUP BY
landing_page
ORDER BY
screen_page_views DESC
Breaking Down the Query:
- Main Query:
- Focuses on key landing page metrics such as screen page views, sessions, engaged sessions, total users, bounce rate, and average engagement time per user.
- Subquery – UNNEST and Data Transformation:
- Utilizes the UNNEST function to transform and extract essential data from event parameters.
- Cleans and structures data for further analysis.
- Metrics Extraction:
- Extracts landing page information, screen page views, session ID, engaged sessions, user pseudo ID, and engagement time (in seconds).
- Time Frame Restriction:
- Filters data based on the desired time frame (e.g., October 2023) for a specific reporting period.
- Calculations:
- Calculates metrics such as bounce rate and average engagement time per user using advanced mathematical expressions.
- Grouping and Aggregation:
- Groups data by landing page to provide insights into the performance of each page.
- Aggregates metrics for a consolidated view.
Output Table:
Conclusion:
By analyzing crucial metrics, organizations can optimize content, enhance user experiences, and strategically tailor their digital strategies. Embrace the power of GA4 analytics, transforming raw data into actionable intelligence for informed decision-making and digital success.
Discover a treasure trove of powerful GA4 queries in our primary blog post, “Top Queries within Google Analytics 4.” Go to our blog area here to read more intriguing blogs of this kind.