
β οΈ Common Mistakes That Break Revenue Tracking
Here are the issues I see again and again:
- Missing the purchaseevent altogethe-especially for non-standard ecommerce platforms or headless setups
- Triggering the purchase tag multiple times-for example, when a user reloads the order confirmation page
- Duplicate transaction_idvalues-leading to GA4 deduplicating real transactions as duplicates
- Sending revenue values on begin_checkoutoradd_to_cart-which inflates reports
- Failing to filter out test/staging data-adding false revenue
- Missing or inconsistent currencyfields-especially dangerous for multi-region stores
- Coupon codes, tax and shipping not being tracked correctly-leading to mismatched totals
If your GA4 revenue doesnβt match your Stripe/Shopify numbers, itβs probably not your backend thatβs wrong. Itβs your tracking.
πΈ The Subscription Trap
One major limitation with GA4 is that it tracks revenue at the point of event, not as recurring payments.
So if someone buys a subscription for Β£10/month, your GA4 report will only show the initial Β£10 at checkout-not future rebills. Thatβs fine for one-time products, but misleading for SaaS or memberships.
What you can do:
- Track each recurring charge via backend server-side calls (requires dev)
- Use BigQuery to stitch together historical user payments over time
- Segment first-time vs. returning revenue in GA4 using custom dimensions
π What About Gift Cards?
Gift cards are tricky.
If a user buys a gift card, GA4 will count that as revenue (on the purchase event).
But when someone spends a gift card, GA4 may also include that in the purchase event-potentially double-counting the value.
Best practice is:
- Track gift card purchases as revenue
- Subtract gift card usage from future purchase valueparameters
- Or set a custom parameter to distinguish βpaid with gift cardβ revenue in BigQuery
π§Ύ Refunds, Tax, and Shipping
- Refunds: GA4 supports a refundevent, but it's often not implemented. Without it, your revenue numbers will always skew high.
- Shipping & tax: You can include these as separate item parameters or roll them into the total value. But whichever route you choose, stay consistent.
 In BigQuery,valueis the total order value, but not broken down unless you send custom item-level parameters.
π‘ Pro Tip: BigQuery Can Be Misleading
Even if youβre piping your GA4 data into BigQuery, be careful-GA4 converts revenue to USD based on the exchange rate at the time of ingestion.
So if youβre reporting across currencies, or doing YoY analysis, you might see inconsistencies.
Solution:
- Always include the original currency in your exports
- Use currencyandvalueto back-calculate in your preferred reporting tool
- For high-accuracy financials, match BigQuery to backend values-not GA4 frontend numbers
β How to QA Your Revenue Tracking
Donβt assume it works. Check:
- Does the purchaseevent fire on the thank-you page (and only once)?
- Is the transaction_idunique and consistent with your backend?
- Are the value,currency, anditemsall present?
- Use GA4 debug view or Tag Assistant to simulate a purchase
- Cross-check totals weekly vs backend/CRM
π§° Bonus: Tools & Checks
- GA4 Debug View
- Real-time monetisation report
- BigQuery event_name = "purchase"analysis
- Custom alerts when revenue drops below thresholds
- My BigQuery checks (https://www.netimpression.co.uk/tools/bigquery-data-quality-checks) can catch the basics too
Final Thoughts
GA4 doesnβt lie-it just reflects what you send it.
If you send broken or bloated data, itβll faithfully show you the wrong answers.
Revenue tracking isn't just about numbers-it's about decisions. If your reports are off, you're targeting the wrong channels, pausing winning campaigns, and misunderstanding what actually converts.
Get it right, and everything downstream improves.
β




