arrow_back

Creating dynamic SQL derived tables with LookML and Liquid

Sign in Join
Test and share your knowledge with our community!
done
Get access to over 700 hands-on labs, skill badges, and courses

Creating dynamic SQL derived tables with LookML and Liquid

Lab 1 hour universal_currency_alt No cost show_chart Intermediate
info This lab may incorporate AI tools to support your learning.
Test and share your knowledge with our community!
done
Get access to over 700 hands-on labs, skill badges, and courses

GSP932

Google Cloud self-paced labs logo

Overview

Looker is a modern data platform in Google Cloud that lets you analyze and visualize your data interactively. You can use Looker to do in-depth data analysis, integrate insights across different data sources, build actionable data-driven workflows, and create custom data applications.

In this lab, you learn how to create and update SQL derived tables to generate dynamic values and address multiple use cases.

What you'll do

  • Create SQL derived tables to address multiple use cases
  • Update a SQL derived table to generate dynamic values using templated filters with Liquid
  • Understand how business users leverage dynamic SQL derived tables to answer complex questions

Prerequisites

Familiarity with LookML is necessary. Completing Understanding LookML in Looker is recommended before beginning this lab.

Setup and requirements

Before you click the Start Lab button

Read these instructions. Labs are timed and you cannot pause them. The timer, which starts when you click Start Lab, shows how long Google Cloud resources are made available to you.

This hands-on lab lets you do the lab activities yourself in a real cloud environment, not in a simulation or demo environment. It does so by giving you new, temporary credentials that you use to sign in and access Google Cloud for the duration of the lab.

To complete this lab, you need:

  • Access to a standard internet browser (Chrome browser recommended).
Note: Use an Incognito or private browser window to run this lab. This prevents conflicts between your personal account and the Student account, which may cause extra charges incurred to your personal account.
  • Time to complete the lab—remember, once you start, you cannot pause a lab.
Note: If you already have a personal Google Cloud account or project, do not use it for this lab to avoid extra charges to your account.

How to start your lab and sign in to Looker

  1. When ready, click Start Lab.

    The Lab Details pane appears with the temporary credentials that you must use for this lab.

    If you need to pay for the lab, a pop-up opens for you to select your payment method.

    Notice your lab credentials in the Lab details pane. You use them to sign in to the Looker instance for this lab.

    Note: If you use other credentials, you will get errors or incur charges.
  2. Click Open Looker.

  3. Enter the provided Username and Password in the Email and Password fields.

    Username:

    {{{looker.developer_username | Username}}}

    Password:

    {{{looker.developer_password | Password}}} Important: You must use the credentials from the Lab Details pane on this page. Do not use your Google Cloud Skills Boost credentials. If you have a personal Looker account, do not use it for this lab.
  4. Click Log In.

    After a successful login, you see the Looker instance for this lab.

Task 1. Create a single SQL derived table to address multiple use cases

In LookML, you can define derived tables using either SQL queries to define a SQL derived table or Explore queries to define a native derived table. Using a SQL derived table is often easier for SQL developers to understand and get started with derived tables in Looker.

In this task, you will create a SQL derived table called user_facts that is flexible enough to answer multiple customer behavior questions such as the following:

  • What is the Average Lifetime Revenue and Average Lifetime Order Count for all customers in each US State?
  • What is the first order date and last order date for a customer, in addition to their Total Revenue (lifetime) and Total Order Count (lifetime)?

Define a new derived table using a SQL query

  1. First, on the bottom left of the Looker User Interface, click the toggle button to enter Development mode.
  1. Click the Develop tab, and then click SQL Runner.

  2. In the SQL Query window, add the following query:

SELECT order_items.user_id AS user_id ,COUNT(distinct order_items.order_id) AS lifetime_order_count ,SUM(order_items.sale_price) AS lifetime_revenue ,MIN(order_items.created_at) AS first_order_date ,MAX(order_items.created_at) AS latest_order_date FROM cloud-training-demos.looker_ecomm.order_items GROUP BY user_id LIMIT 10

In this example, the desired query selects the user_id, counts the lifetime order count for that user, and then sums the prices as a lifetime revenue for the user. It also determines the minimum and maximum values of the created_at column as the first order date and last order date, respectively.

The GROUP BY clause is used to group the results by user_id, and the LIMIT clause is used to limit the results, as you only need to review a subset of records to ensure that your query is working successfully.

  1. Click Run to see the results of your query.

The Results table displaying 10 rows of data

In this example, the query is indeed returning the user ID, the lifetime order count, the lifetime revenue generated from the user, and the first and last order dates.

Notice that the LIMIT clause is used to reduce the amount of data returned during this test; you will remove the LIMIT clause in an upcoming step when you create a new view file for the SQL derived table.

Create a new view file for the SQL derived table

  1. Click on Settings (settings gear icon) next to Run (top right of page), and select Add to Project.

  2. For Project, select qwiklabs-ecommerce.

  3. For View Name, type: user_facts.

  4. Click Add.

You are redirected to the Looker IDE to review the newly created view file for your SQL derived table. You can see that Looker auto-generates a view file for the SQL derived table based on the query you entered in the SQL Runner. The first 12 lines of the view file are shown below:

view: user_facts { derived_table: { sql: SELECT order_items.user_id AS user_id ,COUNT(distinct order_items.order_id) AS lifetime_order_count ,SUM(order_items.sale_price) AS lifetime_revenue ,MIN(order_items.created_at) AS first_order_date ,MAX(order_items.created_at) AS latest_order_date FROM cloud-training-demos.looker_ecomm.order_items GROUP BY user_id LIMIT 10 ;; }

In Looker, your file should resemble the following:

The user_facts.view displaying 10 lines of code

Notice that the new user_facts view has been created outside of the views folder. It is a best practice to keep the view files organized in the project.

  1. Click on the arrow next to views to see the list of views.

  2. Click user_facts.view and drag it under the views folder.

  3. Click user_facts.view to see the view file for the SQL derived table.

Looker auto-generates a dimension for each column in the SELECT clause of the SQL query as well as a new count measure. In the next steps, you modify the view file to remove the LIMIT clause which is no longer desired, hide the new count measure, and add a primary key for the view.

  1. Delete the code line for LIMIT 10 from the sql parameter.

As highlighted previously, Looker auto-generates a count measure along with the dimensions used in the derived table. Sometimes this auto-generated count measure is not valuable, if you already have a count in another view that provides the same number.

In this example, the auto-generated count measure is counting the order IDs, and there is already a count of orders in the order_items view.

You can delete or hide the count measure using the hidden: yes parameter. Hiding the measure is a good idea if you would like to retain it for validation if this count is the same as another count.

  1. In the measure: count definition, add a new line before type: count, and insert the following:
hidden: yes

A final best practice is to make sure that the new view has a primary key.

In this example, you can add the primary_key: yes parameter to the user_id dimension, which is the central organizing ID of this view that provides details about each individual order.

  1. In the dimension: user_id definition, add a new line before type: number, and insert the following:
primary_key: yes

The new view called user_facts is now ready for you to create new dimensions and measures, join it to the explore in the model file, and/or finish out the Git workflow to send your changes to production. You will continue building on this in the next sections.

  1. Click Save Changes. The updated code should resemble the following:
view: user_facts { derived_table: { sql: SELECT order_items.user_id AS user_id ,COUNT(distinct order_items.order_id) AS lifetime_order_count ,SUM(order_items.sale_price) AS lifetime_revenue ,MIN(order_items.created_at) AS first_order_date ,MAX(order_items.created_at) AS latest_order_date FROM cloud-training-demos.looker_ecomm.order_items GROUP BY user_id ;; } measure: count { hidden: yes type: count drill_fields: [detail*] } dimension: user_id { primary_key: yes type: number sql: ${TABLE}.user_id ;; }

In Looker, your file should resemble the following:

The user_facts.view displaying 28 lines of code

Commit changes and deploy to production

  1. Click Validate LookML and then click Commit Changes & Push.

  2. Add a commit message and click Commit.

  3. Lastly, click Deploy to Production.

Click Check my progress to verify the objective. Create the view file for SQL derived table

Task 2. Add measures to answer business questions

In this section, you will add a two measures to answer the initial customer behavior question you were interested in: What is the Average Lifetime Revenue and Average Lifetime Order Count for all customers in each US State?

  1. In the user_facts.view view, add two measures: average_lifetime_revenue and average_lifetime_order_count that calculate the average lifetime revenue and average lifetime order count:
measure: average_lifetime_revenue { type: average sql: ${TABLE}.lifetime_revenue ;; } measure: average_lifetime_order_count { type: average sql: ${TABLE}.lifetime_order_count ;; }
  1. Click Save Changes. Your view should resemble:

The user_facts.view displaying lines 25 to 43 of code, mimicking the layout in the previous step

Join the new view to an Explore

In this section, you will review and test the new derived table. You will first join it to the order_items explore definition in the model file, and then use the Order Items Explore to review what business users would see if you pushed the changes to production.

  1. From the same page, click on the training_ecommerce.model file inside of the model folder to modify its contents.

  2. Locate the explore: order_items definition. Notice that there are several joins already defined such as the one for the users view.

The training_ecommerce.model displaying lines 14 to 28

  1. In the explore: order_items definition, above the existing join for users, add a new join for user_facts by specifying:
join: user_facts { type: left_outer sql_on: ${order_items.user_id} = ${user_facts.user_id};; relationship: many_to_one }

The sql_on parameter identifies the join field as user_id. The relationship parameter identifies that there are potentially many instances of an user_id in order_items but only one instance of each user_id in user_facts, which is organized as one summary row for each order.

  1. Click Save Changes. Your explore should now include the following:
explore: order_items { join: user_facts { type: left_outer sql_on: ${order_items.user_id} = ${user_facts.user_id};; relationship: many_to_one } join: users { type: left_outer sql_on: ${order_items.user_id} = ${users.id} ;; relationship: many_to_one } ... ... ... }

In Looker, your view should now resemble:

The training_ecommerce.model with user_facts explore added, displaying lines 1 to 29

  1. Now that you've joined the view to the Explore, navigate to the Explore page for Order Items.

  2. Under the User Facts view, select the User ID dimension, and the Average Lifetime Order Count and Average Lifetime Revenue measures.

  3. Set the Row Limit to 100.

  4. Click Run. The results should resemble the following:

The results table displaying 10 rows of data for User ID dimension, the Average Lifetime Order Count, and Average Lifetime Revenue measures

  1. Now, remove the User ID dimension and add the State dimension from the Users view.

  2. Click the Country dimension and add a filter on it.

  3. Select USA.

USA filter

  1. Click Run to run the query again.

You can see how the same measures can now be used to calculate one value for Average lifetime revenue and one for Average lifetime order count per user and per state!

  1. Your results should resemble the following:

The results table displaying 10 rows of data for Users country, Users state, Average Lifetime Order Count, and Average Lifetime Revenue measures

  1. Navigate back to the training_ecommerce model file.

Commit changes and deploy to production

  1. Click Validate LookML and then click Commit Changes & Push.

  2. Add a commit message and click Commit.

  3. Lastly, click Deploy to Production.

Click Check my progress to verify the objective. Add measures to answer business questions

Task 3. Update a SQL derived table to generate dynamic values using templated filters

As you saw in the previous lab, templated filters follow the same logical pattern as parameters. Again, the major difference is that templated filters allow end users to choose from a number of filter operators. For the number data type, that could be “is equal to,” “is greater than,” “is between,” and so on.

In templated filters, values are not hard-coded; they are entered by users and then passed onto the generated SQL query. However, you can display a drop-down menu of options by specifying an explore and dimension in the filter definition.

In this section, you will modify the SQL derived table definition from the first section, so that it recalculates all values based on the time frame that a user has selected.

  1. Navigate back to the user_facts view in the Looker IDE.

  2. First, modify the SQL derived table definition as follows to include conditional WHERE clause:

derived_table: { sql: SELECT order_items.user_id AS user_id ,COUNT(distinct order_items.order_id) AS lifetime_order_count ,SUM(order_items.sale_price) AS lifetime_revenue ,MIN(order_items.created_at) AS first_order_date ,MAX(order_items.created_at) AS latest_order_date FROM cloud-training-demos.looker_ecomm.order_items WHERE {% condition select_date %} order_items.created_at {% endcondition %} GROUP BY user_id;; }
  1. Next, add a new filter under the derived_table definition for users to select a date:
filter: select_date { type: date suggest_explore: order_items suggest_dimension: order_items.created_date }

The first 18 lines of the view file should now resemble the following:

view: user_facts { derived_table: { sql: SELECT order_items.user_id AS user_id ,COUNT(distinct order_items.order_id) AS lifetime_order_count ,SUM(order_items.sale_price) AS lifetime_revenue ,MIN(order_items.created_at) AS first_order_date ,MAX(order_items.created_at) AS latest_order_date FROM cloud-training-demos.looker_ecomm.order_items WHERE {% condition select_date %} order_items.created_at {% endcondition %} GROUP BY user_id;; } filter: select_date { type: date suggest_explore: order_items suggest_dimension: order_items.created_date }
  1. Click Save Changes. You file should now resemble the following:

The user_facts.view diaplying lines 1 to 18

Now you will test the dynamic SQL derived table in the Order Items Explore by repeating the queries from the previous task to see that the values change when the filter is added.

  1. Navigate back to the Order Items Explore.

  2. Select the Average Lifetime Order Count and Average Lifetime Revenue measures under the User Facts view.

  3. Select the State dimension under the Users view.

  4. Click on the filter icon next to the new Filter-Only Field called Select Date under the User Facts view.

  5. For the first filter value at the top of the UI, leave “is in the past” selected.

  6. For the second filter value, select complete years and add 1 to the empty value box.

  7. From the Users view, add a filter on Country and set it equal to USA.

  8. Click Run to see the results.

You will see the Average Lifetime Order Count and Average Lifetime Revenue for each state or country for the past 1 complete year.

  1. Click on the SQL tab to review the SQL.

  2. At this point, you can play around with the filter values, and review the SQL tab to see how the templated filter changes the values accordingly.

  3. Navigate back to the user_facts view.

Commit changes and deploy to production

  1. Click Validate LookML and then click Commit Changes & Push.

  2. Add a commit message and click Commit.

  3. Lastly, click Deploy to Production.

Click Check my progress to verify the objective. Update a SQL derived table to generate dynamic values using templated filters

Congratulations!

In this lab, you created SQL derived tables to to generate dynamic values using templated filters with Liquid, and leveraged dynamic SQL derived tables to answer complex questions.

Next steps / Learn more

Google Cloud training and certification

...helps you make the most of Google Cloud technologies. Our classes include technical skills and best practices to help you get up to speed quickly and continue your learning journey. We offer fundamental to advanced level training, with on-demand, live, and virtual options to suit your busy schedule. Certifications help you validate and prove your skill and expertise in Google Cloud technologies.

Manual Last Updated April 24, 2024

Lab Last Tested April 24, 2024

Copyright 2025 Google LLC All rights reserved. Google and the Google logo are trademarks of Google LLC. All other company and product names may be trademarks of the respective companies with which they are associated.