Mapping Many-to-Many Relationships to a Database Diagram
Many-to-many relationships let you relate each row in one table to many rows in another table, and vice versa. For example, you could create a many-to-many relationship between the authors
table and the titles
table to match each author to all of his or her books and to match each book to all of its authors. Creating a
Many-to-many relationships between tables are accommodated in databases by means of titleauthor
table is a junction table.
To create a many-to-many relationship between tables
- In your database diagram, add the tables that you want to create a many-to-many relationship between.
- Create a third table by right-clicking the diagram and choosing New Table from the shortcut menu. This will become the junction table. For details, see Adding Tables to a Database Diagram.
- In the Choose Name dialog box, change the system-assigned table name. For example, the junction table between the
titles
table and theauthors
table is now namedtitleauthors
. For details, see Renaming a Table. - Copy the primary key columns from each of the other two tables to the junction table. You can add other columns to this table, just as you can to any other table. For details, see Copying Columns from One Table to Another.
- In the junction table, set the primary key to include all the primary key columns from the other two tables. For details, see Defining a Primary Key.
- Define a one-to-many relationship between each of the two primary tables and the junction table. The junction table should be at the "many" side of both of the relationships you create. For details, see Creating a Relationship Between Tables.
Note The creation of a junction table in a database diagram does not insert data from the related tables into the junction table. For information about inserting data into a table, see Creating Insert Queries.