Home > Articles > Databases > Access

Working with Multiple-Table Queries in Access

Paul McFedries
  • PrintPrint
  • Share ThisShare This
  • DiscussDiscuss
Close WindowPaul McFedries

Paul McFedries 

Learn more…

Building Basic Formulas in Excel 2010
Jun 8, 2010
Configuring Windows Home Server
May 6, 2010
Getting to Know Mac OS X Finder Windows
Apr 7, 2010
How Paul McFedries Gets Under the Hood of Microsoft Products
Dec 10, 2009
Tweaking the Windows 7 Registry
Jul 17, 2009
Running Scripts to Enhance and Improve Windows
Jun 11, 2009
Building a Budget PC
Jun 16, 2008
Accessing and Sharing Network Resources in Windows Vista
May 28, 2008
Programming the Windows Script Host
Apr 29, 2008
Tricks for Working with Word 2007 Documents
Mar 31, 2008
Building Basic Formulas in Excel 2007
Mar 26, 2008
Collaborating with Windows Meeting Space
Feb 15, 2008
Troubleshooting Tools Included with Windows Vista
Feb 15, 2008
Using Virtual Private Network Connections in Windows Vista
Feb 15, 2008
Implementing Group Policies with Windows Vista
Feb 8, 2008
Programming the Windows Script Host
Feb 8, 2008
Windows Vista's Stability Improvements
Feb 8, 2008
Adding Devices to the Windows Home Server Network
Sep 21, 2007
Understanding Program Variables in VBA
Jun 15, 2007
Designing Microsoft Access 2007 Forms for Efficient and Accurate Data Entry
May 4, 2007
Getting the Most Out of Windows Vista User Accounts
Mar 9, 2007
The Windows Vista Interface
Oct 6, 2006
Mastering File Types in Windows XP
Nov 4, 2005
Constructing Knockout Presentations in PowerPoint
Apr 22, 2005
Working with Multiple-Table Queries in Access
Sep 10, 2004
Building Basic Formulas in Excel
Aug 27, 2004
Understanding Program Variables in VBA
Apr 2, 2004
From Buck-Naked to Beautiful: Dressing Up Your Page
Jun 7, 2002
Performing Financial Calculations
Sep 2, 2001
Creating and Using Cookies
Sep 2, 2001
Encrypting Text with JavaScript
Sep 2, 2001
Making Form Fields Mandatory
Sep 2, 2001
Cross-Browser Solutions: Detection and Generic Functions
Sep 2, 2001
Understanding Variables in JavaScript
Jul 6, 2001
Formulas and Functions: Microsoft Excel 2010Formulas and Functions: Microsoft Excel 2010
May 14, 2010
Formulas and Functions: Microsoft Excel 2010, Portable DocumentsFormulas and Functions: Microsoft Excel 2010, Portable Documents
May 6, 2010
Microsoft Windows Home Server Unleashed, 2nd EditionMicrosoft Windows Home Server Unleashed, 2nd Edition
Apr 5, 2010
Microsoft Windows Home Server Unleashed, Portable Documents, 2nd EditionMicrosoft Windows Home Server Unleashed, Portable Documents, 2nd Edition
Mar 18, 2010
Mac OS X Snow Leopard In DepthMac OS X Snow Leopard In Depth
Sep 22, 2009
Mac OS X Snow Leopard In Depth App (iPhone)Mac OS X Snow Leopard In Depth App (iPhone)
Sep 22, 2009
Mac OS X Snow Leopard In Depth, Adobe ReaderMac OS X Snow Leopard In Depth, Adobe Reader
Sep 15, 2009
Microsoft Windows 7 UnleashedMicrosoft Windows 7 Unleashed
Jul 14, 2009
Microsoft Windows 7 Unleashed App (iPhone)Microsoft Windows 7 Unleashed App (iPhone)
Jul 14, 2009
Microsoft Windows 7 Unleashed, Adobe ReaderMicrosoft Windows 7 Unleashed, Adobe Reader
Jul 8, 2009
Tweak It and Freak It: A Killer Guide to Making Windows Run Your WayTweak It and Freak It: A Killer Guide to Making Windows Run Your Way
Mar 27, 2009
Tweak It and Freak It: A Killer Guide to Making Windows Run Your Way, Adobe ReaderTweak It and Freak It: A Killer Guide to Making Windows Run Your Way, Adobe Reader
Mar 18, 2009
Build It. Fix It. Own It: A Beginner's Guide to Building and Upgrading a PCBuild It. Fix It. Own It: A Beginner's Guide to Building and Upgrading a PC
May 19, 2008
Build It. Fix It. Own It: A Beginner's Guide to Building and Upgrading a PC, Adobe ReaderBuild It. Fix It. Own It: A Beginner's Guide to Building and Upgrading a PC, Adobe Reader
May 7, 2008
Microsoft Windows Vista Unleashed, 2nd EditionMicrosoft Windows Vista Unleashed, 2nd Edition
Apr 4, 2008
Microsoft Windows Vista Unleashed, Adobe Reader, 2nd EditionMicrosoft Windows Vista Unleashed, Adobe Reader, 2nd Edition
Apr 4, 2008
Networking with Microsoft Windows Vista: Your Guide to Easy and Secure Windows Vista NetworkingNetworking with Microsoft Windows Vista: Your Guide to Easy and Secure Windows Vista Networking
Dec 19, 2007
Networking with Microsoft Windows Vista: Your Guide to Easy and Secure Windows Vista Networking (Adobe Reader)Networking with Microsoft Windows Vista: Your Guide to Easy and Secure Windows Vista Networking (Adobe Reader)
Dec 19, 2007
Microsoft Windows Home Server UnleashedMicrosoft Windows Home Server Unleashed
Sep 13, 2007
Microsoft Windows Home Server Unleashed (Adobe Reader)Microsoft Windows Home Server Unleashed (Adobe Reader)
Sep 13, 2007
Tricks of the Microsoft Office 2007 GurusTricks of the Microsoft Office 2007 Gurus
May 16, 2007
Tricks of the Microsoft Office 2007 Gurus (Adobe Reader), 2nd EditionTricks of the Microsoft Office 2007 Gurus (Adobe Reader), 2nd Edition
May 16, 2007
Microsoft Office Access 2007 Forms, Reports, and QueriesMicrosoft Office Access 2007 Forms, Reports, and Queries
May 1, 2007
Microsoft Office Access 2007 Forms, Reports, and Queries (Adobe Reader)Microsoft Office Access 2007 Forms, Reports, and Queries (Adobe Reader)
May 1, 2007
VBA for the 2007 Microsoft Office SystemVBA for the 2007 Microsoft Office System
Mar 30, 2007
VBA for the 2007 Microsoft Office System (Adobe Reader)VBA for the 2007 Microsoft Office System (Adobe Reader)
Mar 30, 2007
Formulas and Functions with Microsoft Office Excel 2007Formulas and Functions with Microsoft Office Excel 2007
Mar 14, 2007
Formulas and Functions with Microsoft Office Excel 2007 (Adobe Reader)Formulas and Functions with Microsoft Office Excel 2007 (Adobe Reader)
Mar 14, 2007
Microsoft Windows Vista Unleashed, Adobe ReaderMicrosoft Windows Vista Unleashed, Adobe Reader
Dec 8, 2006
Microsoft Windows Vista UnveiledMicrosoft Windows Vista Unveiled
Jun 9, 2006
Microsoft Windows Vista Unveiled, Adobe ReaderMicrosoft Windows Vista Unveiled, Adobe Reader
Jun 9, 2006
Special Edition Using JavaScript, Adobe ReaderSpecial Edition Using JavaScript, Adobe Reader
Feb 14, 2006
Microsoft Windows XP UnleashedMicrosoft Windows XP Unleashed
Sep 6, 2005
Microsoft Windows XP Unleashed, Adobe ReaderMicrosoft Windows XP Unleashed, Adobe Reader
Sep 6, 2005
Tricks of the Microsoft Office GurusTricks of the Microsoft Office Gurus
Apr 12, 2005
Microsoft Access 2003 Forms, Reports, and QueriesMicrosoft Access 2003 Forms, Reports, and Queries
Aug 18, 2004
Microsoft Access 2003 Forms, Reports, and Queries, Adobe ReaderMicrosoft Access 2003 Forms, Reports, and Queries, Adobe Reader
Aug 18, 2004
Formulas and Functions with Microsoft Excel 2003Formulas and Functions with Microsoft Excel 2003
Jun 11, 2004
Formulas and Functions with Microsoft Excel 2003, Adobe ReaderFormulas and Functions with Microsoft Excel 2003, Adobe Reader
Jun 11, 2004
Absolute Beginner's Guide to VBAAbsolute Beginner's Guide to VBA
Mar 9, 2004
Absolute Beginner's Guide to VBA, Adobe ReaderAbsolute Beginner's Guide to VBA, Adobe Reader
Mar 9, 2004
Unauthorized Guide to Windows Millennium, TheUnauthorized Guide to Windows Millennium, The
Sep 20, 2000
The Unauthorized Guide to Windows 98, 2nd EditionThe Unauthorized Guide to Windows 98, 2nd Edition
Aug 28, 1999

Sorry, this author hasn't posted any blogs.

Most database applications store their information in multiple tables. Being able to query and work with data from multiple tables requires some front-end planning to set up the tables correctly, and this chapter from Paul McFedries helps you to design databases to make such queries possible.

In this chapter

  • Relational Database Fundamentals

  • Types of Relational Models

  • Enforcing Referential Integrity

  • Establishing Table Relationships

  • Working with Multiple Tables in a Query

  • Creating Other Types of Joins

  • Creating a Unique Values Query

  • Case Study

Most database applications (and all well-designed database applications) store their information in multiple tables. Although most of these tables have nothing to do with each other (for example, tables of customer information and employee payroll data), it's likely that at least some of the tables do contain related information (such as tables of customer information and customer orders).

Working with multiple, related tables in a query presents you with two challenges: You need to design your database so that the related data is accessible, and you need to set up links between the tables so that the related information can be retrieved and worked with quickly and easily in the query design window. This chapter tackles both challenges and shows you how to exploit the full multiple-table powers of Access.

Relational Database Fundamentals

Why do you need to worry about multiple tables, anyway? Isn't it easier to work with one large table instead of two or three medium-sized ones? To answer these questions and demonstrate the problems that arise when you ignore relational database models, take a look at a simple example: a table of sales leads.

The Pitfalls of a Nonrelational Design

Table 3.1 outlines a structure of a simple table (named Leads) that stores data on sales leads.

Table 3.1 A Structure of a Simple Sales Leads Table (Leads)

Field

Description

LeadID

The primary key.

FirstName

The contact's first name.

LastName

The contact's last name.

Company

The company that the contact works for.

Address

The company's address.

City

The company's city.

State

The company's state.

Zip

The company's ZIP code.

Phone

The contact's phone number.

Fax

The contact's fax number.

Source

Where the lead came from.

Notes

Notes or comments related to the sales lead.


This structure works fine until you need to add two or more leads from the same company (a not-uncommon occurrence). In this case, you end up with repeating information in the Company, Address, City, and State fields. (The Zip field also repeats, as do, in some cases, the Phone, Fax, and Source fields.)

All this repetition makes the table unnecessarily large, which is bad enough, but it also creates two major problems:

  • During data entry, the repeated information must be entered for each lead from the same company.

  • If any of the repeated information changes (such as the company's name or address), each corresponding record must be changed.

One way to eliminate the repetition and solve the data entry and maintenance inefficiencies is to change the table's focus. As it stands, each record in the table identifies a specific contact in a company. But it's the company information that repeats, so it makes some sense to allow only one record per company. You can then include separate fields for each sales lead within the company. The new structure might look something like the one shown in Table 3.2.

Table 3.2 A Revised, Company-Centered Structure of the Sales Leads Table

Field

Description

LeadID

The primary key.

Company

The company's name.

Address

The company's address.

City

The company's city.

State

The company's state.

Zip

The company's ZIP code.

Phone

The company's phone number.

Fax

The company's fax number.

First_1

The first name of contact #1.

Last_1

The last name of contact #1.

Source_1

Where the lead for contact #1 came from.

Notes_1

Notes or comments related to contact #1.

First_2

The first name of contact #2.

Last_2

The last name of contact #2.

Source_2

Where the lead for contact #2 came from.

Notes_2

Notes or comments related to contact #2.

First_3

The first name of contact #3.

Last_3

The last name of contact #3.

Source_3

Where the lead for contact #3 came from.

Notes_3

Notes or comments related to contact #3.


In this setup, the company information appears only once, and the contact-specific data (I'm assuming this involves only the first name, last name, source, and notes) appears in separate field groups (for example, First_1, Last_1, Source_1, and Notes_1). This solves the earlier problems, but at the cost of a new dilemma: The structure as it stands will hold only three sales leads per company. Of course, it's entirely conceivable that a large firm might have more than three contacts—perhaps even dozens. This raises two unpleasant difficulties:

  • If you run out of repeating groups of contact fields, new ones must be added. Although this might not be a problem for the database designer, most data-entry clerks generally don't have access to the table design (nor should they).

  • Empty fields take up as much disk real estate as full ones, so making room for, say, a dozen contacts from one company means that all the records that have only one or two contacts have huge amounts of wasted space.

How a Relational Design Can Help

To solve the twin problems of repetition between records and repeated field groups within records, you need to turn to the relational database model. This model was developed by Dr. Edgar Codd of IBM in the early 1970s. It was based on a complex relational algebra theory, so the pure form of the rules and requirements for a true relational database setup is quite complicated and decidedly impractical for business applications. The next few sections look at a simplified version of the model.

Step 1: Separate the Data

After you know which fields you need to include in your database application, the first step in setting up a relational database is to divide these fields into separate tables where the "theme" of each table is unique. In technical terms, each table must be composed of only entities (that is, records) from a single entity class.

For example, the table of sales leads you saw earlier dealt with data that had two entity classes: the contacts and the companies they worked for. Every one of the problems encountered with that table can be traced to the fact that we were trying to combine two entity classes into a single table. So the first step toward a relational solution is to create separate tables for each class of data. Table 3.3 shows the table structure of the contact data (the Contacts table) and Table 3.4 shows the structure of the company information (the Companies table). Note, in particular, that both tables include a primary key field.

Table 3.3 The Structure of the Contacts Table

Field

Description

ContactID

The primary key.

FirstName

The contact's first name.

LastName

The contact's last name.

Phone

The contact's phone number.

Fax

The contact's fax number.

Source

Where the lead came from.

Notes

Notes or comments related to the sales lead.


Table 3.4 The Structure of the Companies Table

Field

Description

CompanyID

The primary key.

CompanyName

The company's name.

Address

The company's address.

City

The company's city.

State

The company's state.

Zip

The company's ZIP code.

Phone

The company's phone number (main switchboard).


Step 2: Add Foreign Keys to the Tables

At first glance, separating the tables seems self-defeating because, if you've done the job properly, the two tables will have nothing in common. So the second step in this relational design is to define the commonality between the tables.

In the sales leads example, what is the common ground between the Contacts and Companies tables? It's that every one of the leads in the Contacts table works for a specific firm in the Companies table. So what's needed is some way of relating the appropriate information in Companies to each record in Contacts (without, of course, the inefficiency of simply cramming all the data into a single table, as we tried earlier).

The way you do this in relational database design is to establish a field that is common to both tables. You can then use this common field to set up a link between the two tables. The field you use must satisfy three conditions:

  • It must not have the same name as an existing field in the other table.

  • It must uniquely identify each record in the other table.

  • To save space and reduce data entry errors, it must be the smallest field that satisfies the two preceding conditions.

In the sales leads example, a field needs to be added to the Contacts table that establishes a link to the appropriate record in the Companies table. The CompanyName field uniquely identifies each firm, but it's too large to be of use. The Phone field is also a unique identifier and is smaller, but the Contacts table already has a Phone field. The best solution is to use CompanyID, the Companies table's primary key field. Table 3.5 shows the revised structure of the Contacts table that includes the CompanyID field.

Table 3.5 The Final Structure of the Contacts Table

Field

Description

ContactID

The primary key.

CompanyID

The Companies table foreign key.

FirstName

The contact's first name.

LastName

The contact's last name.

Phone

The contact's phone number.

Fax

The contact's fax number.

Source

Where the lead came from.

Notes

Notes or comments related to the sales lead.


When a table includes a primary key field from a related database, the field is called a foreign key. Foreign keys are the secret to successful relational database design.

Step 3: Establish a Link Between the Related Tables

After you have your foreign keys inserted into your tables, the final step in designing your relational model is to establish a link between the two tables. This step is covered in detail later in this chapter (see "Establishing Table Relationships").

  • Share ThisShare This
  • Your Account

Discussions

Make a New Comment

You must log in in order to post a comment.

Related Resources

Buck WoodyDealing with Data Defining the Components to Tune
By Buck Woody on 0:00 No Comments

I've been reading a fascinating article about the Large Hadron Collider, or LHC facility. It's a scientific research facility that houses a particle collider, which generates an incredible amount of data. Their original plan was to stream the data to tape, then sending the data to "islands" closer to the users, offloading the network as quickly as possible. But they found that the network could handle the streaming better than they thought - so they now stream the data directly to the users, saturating the network. It's a new way of thinking about moving the data around.

Buck WoodyWork Swarms
By Buck Woody on August 24, 2010 No Comments

I’ve been reading some excerpts from Gartner, Inc. and information from others on the changes they are seeing in the workplace. It’s holding true where I work and in the workplaces of the other data professionals I work with. One of those new trends is called “Swarming” – where informal teams get together to work on a particular project, and in some cases a single task, as a group. They then move on to another task, and so on, like a swarm of bees. These are less formal than the “Tiger Teams” I used to be part of that were also temporary, but had a more formal banding and dis-banding. The Gartner article states that this is more often the norm in companies than not.

Buck WoodyA combination of crowdsourcing, people helping people, and the best technical community there is
By Buck Woody on August 19, 2010 No Comments

I talk a lot about “giving back”. It’s a personal issue with me – I grew up quite poor, and from time to time someone would take notice that my mom and I didn’t have enough to eat, and they would help us out. I’ve never forgotten those folks.

See All Related Blogs

Informit Network