Power Query: Merging Muddles
24 February 2021
Welcome to our Power Query blog. This week, I look at how to merge data when there is not a clear link between the tables.
I have some sales contact data for my imaginary business. Unfortunately, I have some complaints and I want to allocate them to the correct salesperson. I have the date of the complaint and the date the salesperson took over as the primary, as follows:
data:image/s3,"s3://crabby-images/ba484/ba48428718b3b9b399f8d6e33d135dd247dcb5b1" alt=""
I start by extracting my data and importing it into Power Query. I have two tables. I click somewhere in my first table and I choose ‘From Table/Range’ on the ‘Get & Transform’ section of the Data tab.
data:image/s3,"s3://crabby-images/a8aa4/a8aa42d72812a4f75e344505e8efef27b560df85" alt=""
I accept the defaults (as usual!) and click OK.
data:image/s3,"s3://crabby-images/65a39/65a392331be047a2265d0987a85df41bf2457048" alt=""
I ‘Close & Load’ my first table and repeat this process for the other table.
data:image/s3,"s3://crabby-images/9795e/9795eb331aa4b1da3ad360a1219d09bd07aa0a1b" alt=""
I now have two tables, which I have called ‘Key Salesperson’ and Complaints.
data:image/s3,"s3://crabby-images/eaa72/eaa72e7ea375fdf39cd82c6e2601e88416158eba" alt=""
I am going to merge my tables, so I choose ‘Merge Queries’, then ‘Merge Queries as New’, from the Combine section on the Home tab. I choose to create a new table because I am going to join my tables in another way next time…
data:image/s3,"s3://crabby-images/a758a/a758a4d6a7728702ae42ac39d29547895880dd3f" alt=""
In the join options, I can see that the dates are not going to help me join my tables: I need to use a full outer join.
data:image/s3,"s3://crabby-images/9e804/9e8048f102fe8665a71ed761f628680fc9f05ae9" alt=""
When I choose this, I can see there is more work to do to get the data into the format I require.
data:image/s3,"s3://crabby-images/6de7a/6de7aaf66844789b48313bb88a50c1ccd2b6ed66" alt=""
I start by expanding the Complaints table, using the icon next to the column heading.
data:image/s3,"s3://crabby-images/a2c4d/a2c4d2ee3b3254514dc3192141757b1967141e4a" alt=""
I don’t need to use the prefix option as my columns have unique names.
data:image/s3,"s3://crabby-images/a3e16/a3e16e9862a41de55109fc72abc470ac5dbc7905" alt=""
I create a new date column which will hold whichever date is populated.
data:image/s3,"s3://crabby-images/b46db/b46db51a865b6fa5d2fb5dd760ea73a2da99fe24" alt=""
I click OK to create Incident Date.
data:image/s3,"s3://crabby-images/36cf6/36cf6357cc76b37535bbab0536d7bb33c4cc88ea" alt=""
I remove the other date fields and sort on Incident Date.
data:image/s3,"s3://crabby-images/f84cb/f84cb4f29e091cc84f13cf6696afcd626e5f40e8" alt=""
I fill down the salesperson name by selecting Primary Salesperson, right-clicking and selecting Fill and then ‘Fill Down’.
data:image/s3,"s3://crabby-images/65200/65200db6f4b72b80fd42b880044205419607ee43" alt=""
Finally, I select out rows where Complaint Description is null.
data:image/s3,"s3://crabby-images/26438/26438d18a684fe846d638a72b67d7d188f69ee24" alt=""
This gives me the data in the required format:
data:image/s3,"s3://crabby-images/caf23/caf237e4ae0030be9023bc1f8d33972ef42a09fc" alt=""
Next time, I’ll look at a much quicker way to achieve this result…
Come back next time for more ways to use Power Query!