Power Query: Hot Cross Joins
25 April 2018
Welcome to our Power Query blog. This week I look at cross joins.
I have a list of expenses that my fictional salespeople have incurred in a month. I’d like to expand this to estimate what they might spend in the next 10 months.
data:image/s3,"s3://crabby-images/b7577/b7577dcb6d6e458cd94f8097462f6853669f8409" alt=""
I start by creating a query from my expenses data, by choosing ‘From Table’ in the ‘Get and Transform’ section of the ‘Data Tab’:
data:image/s3,"s3://crabby-images/2524a/2524a63629e11feee3c7b5da93857f1dcb78e3b7" alt=""
I confirm where my data is, and that the first line contains the headers. It doesn’t matter that my data is not currently in a table: Power Query will convert it to a table as part of the process.
data:image/s3,"s3://crabby-images/ff735/ff735ce9d05aa633ca6839338ada95c92f53a042" alt=""
My query is shown below. I call it ‘Expense_Forecast’ and save it as connection only.
data:image/s3,"s3://crabby-images/b924e/b924e59de01490446d9967499f4a4f756e7e8554" alt=""
Now I want to create a list of months – this is easy enough to do by creating a new blank query from the ‘New Query’ option in the ‘Get and Transform’ section of the ‘Data’ tab, viz.
data:image/s3,"s3://crabby-images/d5b25/d5b25a993a389fd9cf4880162454d17c7ef13ed6" alt=""
I create a list using basic list functionality (more on this may be found in Power Query: Birthday Lists.
data:image/s3,"s3://crabby-images/2c616/2c6166f80b57372c0a06967c9173bce9ba9de11f" alt=""
The formula I have used is
= {“0518”, “0618”, “0718”, “0818”, “0918”, “1018”, “1118”, “1218”, “0119”, “0219”}
In order to link this list to my ‘Expense_Forecast’ table, I want this to be a table too, so I convert it using the ‘To Table’ option in the ‘Convert’ section of the ‘Transform Tab’. I rename my column and call the query ‘Month_Numbers’. I save this query as connection only too.
data:image/s3,"s3://crabby-images/cf1e3/cf1e3797d6ddad6ae7723ff56deb011db970ffc0" alt=""
So now I need to combine my information. I decide to do this by adding the expense information to my ‘Week_Numbers’ query. I can do this by going to the ‘Add Column’ tab. I choose to add a ‘Custom Column’.
data:image/s3,"s3://crabby-images/f4707/f4707426f227a22122ba24d94b872f92c8fde2fb" alt=""
If I expand the ‘Queries’ pane to the left of my screen, I can use the name of my other query in the column.
data:image/s3,"s3://crabby-images/5712a/5712ac94e486d4ca9760dd00ba1264d0a8472fc8" alt=""
This will create a new column for my ‘Expense_Forecast’ data.
data:image/s3,"s3://crabby-images/9544c/9544c7a9aad77eb2313f9a909530f92f0583dbaf" alt=""
I can now expand my column to show the data in the table – in this case I will choose all the available data. All I need to change, is to untick the ‘Use original column name as prefix’ option (no, I don’t know why it’s the default either!).
data:image/s3,"s3://crabby-images/fb6e8/fb6e89f9d49e41a848b96f0bc5362ae0fa93a045" alt=""
I can then see the basic expense forecast for each employee and category for the next 10 months. I can then upload this data to Excel or PowerPivot and further investigate with the effects of inflation and predicted workloads.
data:image/s3,"s3://crabby-images/ed542/ed54231c28ea4580e2942ff7c5f2ce9beaef6a93" alt=""
Want to read more about Power Query? A complete list of all our Power Query blogs can be found here. Come back next time for more ways to use Power Query!