Warehouse Segments

Warehouse segments enable you to create segments on MoEngage based on data from your data warehouse without the hassles of copying or moving it to MoEngage. 

Let's say that your brand wishes to offer exclusive discounts to loyal shoppers based on an engagement score that is computed with your proprietary logic. This data is stored and accessible only from your data warehouse. With Warehouse segments, you can access this data from the warehouse directly, build an audience on MoEngage, and send a campaign from MoEngage within a few clicks.

With Warehouse segments, you get real-time access to warehouse data without any syncing delays, accelerating audience generation and enabling timely engagement. Moreover, with data securely stored within the warehouse, Warehouse segments ensure data security, simplifying compliance with privacy regulations and industry standards.

 

Early Access

Warehouse segments for Google BigQuery is currently in early access.

Creating a Warehouse segment

Step 1: Set up your data source

Follow the below steps to grant read access to certain tables in BigQuery to Moengage. Additionally, it covers providing access to BigQuery Jobs API, enabling Moengage to submit jobs and download query results.

These instructions assume you have administrative privileges in the Google Cloud Platform, specifically in the project that hosts the BigQuery dataset and jobs.

Create a Service Account for MoEngage

  1. Open the Google Cloud Console.
  2. Navigate to the project housing the BigQuery dataset and jobs.
  3. Go to the IAM & Admin section and select Service Accounts.
  4. Click Create Service Account.
  5. Provide a name for the service account (e.g., moengage-access).
  6. Set the appropriate role for the service account as BigQuery Job User.

  7. Create the service account.
  8. Navigate to the service account and select the KEYS tab.
  9. Click the ADD KEY dropdown and then select Create new key.
  10. Select JSON as the Key type in the pop-up.
  11. Click CREATE to generate and download the JSON key file.

  12. Keep the JSON key file securely and share it with MoEngage as below.

Share the below details to warehousesegments@moengage.com to get warehouse segments enabled on your workspace:

  1. JSON key file of the service account created for MoEngage as per the steps above
  2. Your MoEngage workspace name along with your data cluster (DC) 
  3. Your BigQuery location

Share Access to Specific Tables with Moengage

  1. In the BigQuery console, navigate to the dataset containing the tables you want Moengage to access.
  2. Click the SHARING dropdown and then select Permissions.

  3. Add the service account's email address (found in the JSON key file) as a member with the "BigQuery Data Viewer" role.

  4. Click Save to grant access to the dataset.

Grant Access to BigQuery Jobs API

Skip if access is already given in the first step.

  1. In the Google Cloud Console, go to the IAM & Admin section and then select IAM.
  2. Click Grant Access to add a new member.
  3. Enter the service account's email address (found in the JSON key file).
  4. Assign the Role as BigQuery Job User to enable interaction with the BigQuery Jobs API.
  5. Click Save to grant access to the API.
arrow_drop_down Limit Access to Specific Tables (Optional)
  1. Open the JSON key file shared with Moengage.
  2. Locate the private_key_id attribute in the JSON content.
  3. In the BigQuery console, open the dataset with the desired tables.
  4. Select the table(s) you want to restrict access to and click on "Share Table" from the context menu.
  5. Add the service account's email address as a member and restrict the role to "BigQuery Data Viewer" only for these table(s).

By following the above steps, you have successfully granted Moengage read access to specific tables in BigQuery.

Additionally, you have authorized access to the BigQuery Jobs API, allowing them to submit jobs and download query results.

It is essential to review and manage access permissions periodically to maintain data security.

Step 2: Run a warehouse query

  1. Navigate to the Warehouse segment tab under Segment on the MoEngage dashboard.
  2. Here, you will be able to choose the data warehouse (that has been set up from the previous step) from the Source dropdown on the top.
  3. Once a source is chosen, the data warehouse schema - database, tables, and columns, will be populated on the left panel. From here, you can search for any database, table, or column that you want to use in your query.
  4. You can enter your SQL query in the SQL editor on the right. You can perform any operations such as joining multiple tables, sub-queries, aliases, etc. as required to return your optimal results.
  5. Click on Run Query to run the SQL query in your data warehouse. You should be able to see a new row added in the Query results section below.2024-11-26_17-24-56.gif
  6. The Query results section provides a list of recently run warehouse queries with query metrics such as Run time, Data scanned, and Number of rows of data returned by a specific query from your data warehouse. These metrics are useful for gauging the performance of the queries on your data warehouse. Metrics can be used to optimize your queries while you write them on MoEngage.
  7. The Query results section also provides the status of each warehouse query run from MoEngage. The status can be one among - Successful, Failed, and Processing. 
  8. Once a query has run successfully, you should be able to expand the row from the Query results section and see the sample results of each query. We show up to 100 rows and 10 columns of data for each query. 
  9. Each query result also has a set of actions that can be accessed from the 3-dot menu on each row. 
    • Insert in SQL editor: You can directly insert a particular SQL query on the editor from the Query results section.
      Do note that this action will replace any existing query in the editor.
    • Create a custom segment: You can directly create a custom segment from any query result. However, we expect the query to return a single column of IDs (the unique user identification that is present as an ID in MoEngage) in order to be saved as a custom segment. Hence this option will be active only for those queries that return a single column.
    • Copy query: This action will copy the query to the clipboard.
    • Run query: You can run the query from Query results directly using the Run query action. A new row will be added to the Query results section at the top for the new execution.
    • Download results: You can download the results of a query using the download results action. The downloaded file will contain a maximum of 100 rows and 100 columns of dataScreenshot 2024-11-22 at 4.05.36 PM.png
  10. Preview Table: Now you can one-click preview a few sample rows from any table listed in the schema section. On hovering over a table name in the schema, you should be able to see an eye icon, clicking on this will run a sample query on the table providing up to 10 rows of data as a preview.Screenshot 2024-11-22 at 3.54.30 PM.png
warning

Warning

1. The SQL query must return a single column of IDs in order to be saved as a custom segment. If the query returns multiple columns, the segment will not return any users.

2. The SQL query runs on your data warehouse directly. Please note that when utilizing this feature you will incur the costs associated with running the queries from your data warehouse.

3. The SQL query will timeout in 15 min. Reach out to your CSM to configure this limit.

4. The SQL query should be compatible with your DWH. For eg: If you are using the Warehouse segment on BigQuery, the SQL query must be supported by GoogleSQL

Step 3: Define a warehouse custom segment

Once the SQL query is finalized, you can proceed to create a custom segment. We expect the custom segment query to return a single column of IDs (the unique user identification that is present as an ID in MoEngage). Give a name and a description for the segment.

Screenshot 2024-06-26 at 3.37.51 PM.png

Step 4: Use the warehouse custom segment

Custom segments created using warehouse segment are of type SQL - external. They will be listed on the All Segments page.

Screenshot 2024-11-26 at 5.44.51 PM.png

Actions possible on external custom segments:

  • View - View the details of the custom segment on the segment info page. Here you can:
    • View the SQL query that defines the segment
    • Run the custom segment to update user count - This is when MoEngage connects to your data warehouse, runs the SQL query, and updates the user count.
  • Edit - You can edit the SQL query that was used to define the custom segment
  • Create campaign - You can create a campaign directly from the All Segments page. The target audience section of campaign creation will be populated with the selected custom segment. 
  • External data warehouse segments can be combined with other custom segments as well as user attributes, and behaviors captured in MoEngage. 

Refresh the user count of a Warehouse segment

You can update the user count of an external data warehouse segment in two ways:

  • On campaign run-time - The data warehouse segment that is part of the Target audience of a campaign will auto-refresh at the campaign run-time.
  • Run the custom segment from the segment info page - You can also run the segment manually from the segment info page.

nandhini scr rec2.gif

Considerations

  • One warehouse segment can be defined on one data warehouse connection. You can combine multiple custom segments pointing to different sources and create a new custom segment.
  • Running analysis - Behaviour, Funnel, etc. will not refresh the user count of a warehouse segment. The target audience containing a warehouse segment will either:
    • Return 0 if the segment has never run
    • Return the last run count of users if the segment has run before

 

 

Was this article helpful?
2 out of 2 found this helpful

How can we improve this article?