If you use GA4, you can follow official documentation from Google on how to set up BigQuery Export.
For Google Analytics 4, Google still has not provided free options to export raw data to BigQuery or any other database for that matter. But what if you don’t have plans to migrate to GA4 and want to get the benefits of BigQuery raw data? I decided to solve this question with GTM Server Side tagging and created this how-to article for you.
1. gtag.js sends GA4 event to Google Tag Manager Server container.
2. GA4 client gets the request and triggers JSON HTTP Request Tag.
3. JSON HTTP Request Tag sends data to the URL of the Request To Google Cloud Storage function.
4. GCS function saves data on your GCP Storage bucket.
5. Use BigQuery GCP table type to perform data querying.
1. BigQuery can use Google Cloud Storage bucket as a table. More info about this feature can be found in this official documentation.
2. You can store on GCS 5 GB of data for free. One GA4 request is near 1 KB, so that’s 5 242 880 requests. More details about GCS pricing can be found on the pricing page.
3. The First 2 million requests to Cloud Functions are free, so that’s more than enough for our task. But bear in mind that you need to check usage and pricing if you already use it.
I decided to divide this how-to into two parts. First, I will tell you how to save data that came in request on GCS. And in the second part, I will tell you how to query this data with BigQuery. I hope this helps, and you will get the desired result faster.
Using this how-to, you can store data from any GTM Server Side client, not only Google Analytics 4.
1. We will start by creating a Google Cloud Storage bucket that will contain our raw event data. Search for Storage product in GCP search prompt. Then click on “Create Bucket”
2. Choose a name for your bucket, click “Continue” and choose region “us-central1”. Leave other options with default values.
3. Now you need to create a Google Cloud function that receives data from Google Tag Manager Server Side Container. To do this, go to Google Cloud Developer Console and open the Cloud Function section. Then, click “Create Function”.
4. Fill in the name of the function and select the “Allow unauthenticated invocations” Authentication option. Copy “Trigger URL” because we will use it in the next steps. Click on the Next button at the bottom of the page.
5. Set “Entry point” field to “init”. Also, copy the content of this file and paste it into the code window. You need to change ‘your-bucket-name’ to the bucket name you’ve created in the previous steps. Also, change ‘very-secret-random-key’ to some random key. We will need it in the future. The runtime needs to be set to Node.js 10. One more thing, you need to edit the package.json file. Put this file content into it.
6. Now you can click on the deploy button. Google Cloud needs a few minutes to create the function for the first time so wait a little bit before deploying.
7. Time to create a tag inside the GTM Server container. If you don’t have Google Tag Manager Server-Side Container, you can follow this instruction for creating it. Also, you need to have a JSON HTTP request tag template installed on your GTM Container. If you don’t have it, follow this instruction for adding. Create a new JSON HTTP request tag and fill “Destination URL” with the URL you got when creating Cloud Function in step 4 and add to the end of it your secret key like this “?key=your-secret-key”. Don’t forget to add the trigger you use to determine Google Analytics 4 (check my screenshots for this step).
8. Publish GTM Server container changes and generate test requests to GA Tag. You can simply open your website. If you did everything right, you will see files generated on the Google Cloud Storage bucket.
If you set up storing raw events on GCS correctly, I salute you! The hardest part is done. Let’s follow a few more steps before you can start query data.
1. Go to BigQuery product in GCP and click on the “create dataset” button.
2. Leave all options by default just fill the name field.
3. Now let’s create a table in this dataset. Click on “create table”. In the source selector, choose “Google Cloud Storage”. Field “Select file from GCS bucket” has to look like this: “your-bucket-name/*.json”. Table type set to “External table”. Choose any table name you want. Check the “Auto detect” option. At the end of this form, click on the create table button.
4. Now you can query your data. Click on the query table data button and set “*” as the field name. Run query. If you did everything right, you will see raw GA data in query results.
Please feel free to ask any questions about GA4 events export in the comments or our customer support channels.
Just tell us where you are stuck. Click Need assistance, fill up the form, and we will send you a quote.