[Analytic Block] Flexible Period-over-Period Analysis

Show first post

38 replies

I used the period over period structure above and combined it with the join on false approach here to do something similar on Google BigQuery.

Goal: Compare any two arbitrary periods from the same table with varying levels of granularity (e.g. broken up by day, month, quarter, year, etc.)

Examples below are based on weather data but the approach can be adapted to any table that has date and a measure of interest.

Example 1: Comparing two months (July, 2018 and March, 2018) at the day level

Example 2: Comparing two quarters (Q1, 2018 and Q3, 2018) at the month level

LookML Highlights:

  1. sql_on: FALSE - when using an outer join it accomplishes the equivalent of a wide union, think of a diagonal table with lots of nulls

  2. extracting info from Looker-generated predicate after it translates liquid condition - allows us to determine when both of the arbitrary periods start

  3. using a parameter to label a dimension - shows Week/Day/etc. in the viz based on user’s input

Gist to LookML

Hope others find it useful!

Hey guys,

I’m trying to implement this code in our MS SQL Server environment and I get the error

“always_join: Unknown Join pop”

Not sure what causes this and how I can fix it…

Userlevel 7
Badge +1

That error says to me that there’s something iffy with the way you’ve defined your views. In the code in the top level post here, at the very end, there’s a view defined called pop that’s joined into some explores:

view: pop {

sql_table_name: (SELECT NULL) ;;

view_label: "[PoP]"

etc etc

Is that also present in your LookML? If you’ve renamed it, then that would also break the always_join reference to it.

Hey Miguel, I like your solution but could you please elaborate on your example model with the weather_raw measure and weather_date dimension? I tried to create the weather_raw as an average temperature and create a weather_date dimension but I received an error “Field references an aggregate but is specified as a “dimension”. If you want to use aggregations such as sum, average, count, use a measure type instead.”

@fabio: What does this piece of code actually do? I’m used to using SQL_TABLE_NAME as a reference to a derived table as in ${some_pdt.SQL_TABLE_NAME}


Userlevel 7

That declaration, and the two that follow it are 100% informational for the person implementing the code as to how to do the substitutions in the following code block.


I named it like the existing SQL_TABLE_NAME gesture because it is doing the same thing, providing the name of the table that should be referenced.

Final note, this was necessary back in the day to work around the fact that Looker would not do substitutions inside of the view>sql_table_name parameter. There are surely cleaner ways of implementing this now, but anyway I usually suggest to people not to use this pattern anymore and instead to use on pivots + built-in datepart dimensions, like day_of_month (along with a solution like “outer join on false” or “join paths” if they need to combine datasets without fanout)

@fabio Would you be willing to post the “cleaner” way to implementing this code now? I would greatly appreciate it.

Userlevel 7

I mostly recommend customers away from this approach nowadays and instead suggest using Looker’s default dateparts together with pivoting for a better user experience, and then using something like my join paths approach if there is a need to combine multiple fact tables. This allows for less manually written SQL and better drill downs.

If you are set on using the “PoP” approach in this article, the thing I was alluding to before is that I believe you should now be able to use, for example, ${order_items.SQL_TABLE_NAME} inside of the view>sql_table_name parameter

Hi fabio - thanks very much for this. I’m wondered if you could expand on your statement, “… suggest using Looker’s default dateparts together with pivoting…” or point me to the documentation that discusses this as a way to do PoP analysis, please?

Userlevel 7

For example, you can select “month of year”/“monthname” as a dimension and “year” as a pivot.

When doing this, I find it helps to put the two classes of date parts (i.e., period, and within-period) into two separate view labels.

It can also help to create YTD, MTC, etc filters. Here are a couple examples of that:

Hi, I m trying to adapt this for PostgreSQL but i m stucked !!!

It would be great if you post the equivalent code if exists


I have used the same logic mentioned above for redshift dialect here and I am seeing 7 months when I choose (is in the past :6 months) This also works the same when I select complete months - I am able to see May 2021 when I choose complete months. Same is the case for complete quarters as well. Anyone face the same issue here?


Thanks for sharing @fabio .  Can you help me with below scenario?

Need help in getting past 4 quarters of data based on the filter selection on dashboard.

In the source table, we have data at quarter level ( have Year and Quarter column with other measures)

Year  Quarter Orders
2019  1        100
2019  2        200
2019  3        50
2019  4        90
2020  1        300

On the dashboard, have a filter in which user will select the Quarter ( this filter will have values like 2019Q1,2019Q2 so on which utilizes a dimension built using Year and Quarter)
Once the user selects the Quarter, then the visualization should only show past 4 quarters of data.

New to looker, any help here would be appreciated.