Excel isn’t a database, but that hasn’t stopped people from using it as one.
People have been doing this since early versions of Excel and creating relationships between different tables using VLOOKUP or INDEX and MATCH.
The good news is that more and more database-like functionality is being added with each version, and since Excel 2013 we’ve been able to add relationships to tables.
This example has an Orders table that contains data related to customer orders such as the Customer ID, Product Sold, and the Total.
Another table called Customers has the Name and Country for each Customer ID. But what do you do if you want to analyze the Orders data by customer Name or Country?
One solution would be to add two more columns to the Orders data and use a VLOOKUP function to bring in the customer Name and Country based on the Customer ID.
Another more elegant solution would be to use the pivot table Data Model to create a Relationship between the Orders table and the Customers table using the Customer ID field in both tables.
Create a table based on the Orders table.
Go to the Insert tab in the ribbon and select Pivot Table from the Tables section.
From the Create PivotTable menu.
- Select your Orders Table.
- Check the Add this data to the Data Model box.
- Press the Ok button.
Repeat these steps for the Customers table.
With either of your pivot tables created, you should see both tables in the PivotTable Fields window from the All view.
You can delete one of the pivot tables created since you only need one, the data will remain in the Data Model.
Build your pivot table with the Name from the Customers table in the Rows area and Total from the Orders table in the Values area.
- Drag the Name field from the Customers table to the Rows area. Expand the table to see fields by clicking the arrow next to the table name.
- Drag the Total field from the Orders table to the Values area.
- A notice will appear above the field list saying Relationships between tables may be needed. From here you can select Auto-Detect and let Excel guess the relationships between your tables or you can Create them yourself.
If you choose Auto-Detect, Excel will work to create the relationships and you can check the results by pressing the Manage Relationships button or just Close the window.
With this simple relationship, Excel is easily able to create the relationship. Small tables and consistent field names between tables will help Auto-Detect to work.
If you choose to Create the relationships yourself then the Create Relationship menu will open.
- Select the Orders table as the main Table.
- Select Customer ID as the Column (Foreign).
- Select the Customers table as the Related Table.
- Select Customer ID as the Related Column (Primary).
- Press the OK button to finish creating the relationship.
Now your resulting pivot table contains the customer Name from the Customers table along with the correct corresponding Total from the Orders table.
You can also create these relationships before trying to build the pivot table. You can do this from either the Data tab or the Analyze tab in the ribbon.
- Find the Relationships button in the Data tab under the Data Tools section.
- Find the Relationships button in the Analyze tab under the Calculations section.
This will open the Manage Relationships dialog box.
- Here you can see the existing relationships and select them to Edit, Activate, Deactivate or Delete.
- Create any new relationships using the New button.
This is an awesome way to avoid VLOOKUP or INDEX and MATCH, and minimize the columns in your tables.
Your notes are helpful.