Power Query: Selective Staffing Part 7
8 December 2021
Welcome to our Power Query blog. This week I look at an example that considers values that can be marked as included or excluded.
Last week, I was looking at an example where I had a table of quote data for each of my salespeople, and a list of salespeople that I wished to view quote details for:
data:image/s3,"s3://crabby-images/45635/45635f84b197418ad95bc6b162c9490dbf5c3047" alt=""
I used an Inner Join to merge the data to get the solution:
data:image/s3,"s3://crabby-images/b2a06/b2a064261513d58a3eec78e7f1e94002cd6c4f74" alt=""
This time, I will look at how I can expand this to allow me to consider inclusion and exclusion in the same example. To begin with, I will consider the following situation:
data:image/s3,"s3://crabby-images/8843f/8843f322ca088987208b79c4c41f127ded0da020" alt=""
I begin in exactly the same way as last week, by extracting the tables to Power Query using ‘From Table/Range’ in the ‘Get & Transform’ section of the Data tab.
The quote data is in table Staff_Quotes_Join_E:
data:image/s3,"s3://crabby-images/27dcb/27dcb98cda6c0c0f57024877a234a2cb9840cfc0" alt=""
The staff to be excluded are in table Quote_Selection_Join_E:
data:image/s3,"s3://crabby-images/1a7ea/1a7ea0a8f2e13240b9558116921eb21dc4bd6461" alt=""
I can exclude these values by performing a join. I do this from ‘Merge Queries from the Home tab.
data:image/s3,"s3://crabby-images/f4573/f4573aa2d59ccb2e88b69eb5819d049b801cb49c" alt=""
This time, I will use a Left Anti Join, which will show me the rows that are only in Staff_Quotes_Join_E and NOT in Quote_Selection_Join_E. I need to specify the columns to compare:
data:image/s3,"s3://crabby-images/67c98/67c98350e52c5b2d4b24ee2d1d750bee4dbb2fdd" alt=""
This sounds exactly like what I need, so I click OK.
data:image/s3,"s3://crabby-images/96356/96356854241d1babfcbad886331b34042943221c" alt=""
I can delete the Quote_Selection_Join_E column to get the data I need:
data:image/s3,"s3://crabby-images/18189/18189b2bd5b941b1608ea07e242d2d715cdb4b8a" alt=""
Now I will consider the situation where we have a list staff that are marked as included or excluded.
data:image/s3,"s3://crabby-images/d1c43/d1c4393f50750fdc16edcc74a08796217d5494de" alt=""
This time, I am linking to a table that includes all the salespeople, and they have a flag next to their name. I extract the new data into a table called Quote_Selection_Both:
data:image/s3,"s3://crabby-images/b1318/b1318b5548a36ca5e5ffccb1727903911c9c77c8" alt=""
I can still solve this with a merge, but I need an extra row in Staff_Quotes_Join_E:
data:image/s3,"s3://crabby-images/81787/817871942ff42762a46eead8959c42f3cfa6c533" alt=""
This highly complicated column always has the value “I” and will simply allow me to merge with Quote_Selection_Both.
data:image/s3,"s3://crabby-images/0ccbd/0ccbd46a5849d011c05a49ebea0dec11801d0071" alt=""
I have used an Inner Join to keep the rows I need:
data:image/s3,"s3://crabby-images/21f91/21f916aa1920d339539c687f91223b3d3d875a79" alt=""
I can now delete Include and Quote_Selection_Both to get the data I need:
data:image/s3,"s3://crabby-images/ad90e/ad90e7078be55f4d6b194de5ec2ed79e7cdc6dd9" alt=""
Come back next time for more ways to use Power Query!