By Hemanta Sundaray on 2022-12-06
Let's say we have three tables: orders, subscriptions, and customers.
Each of these tables has a column that uniquely identifies each row of that table:
These special columns are called primary keys.
Primary keys have a few requirements:
Let’s reexamine the orders table:
order_id | customer_id | subscription_id | purchase_date |
---|---|---|---|
1 | 2 | 3 | 2022-01-01 |
2 | 2 | 2 | 2022-01-01 |
3 | 3 | 1 | 2022-01-01 |
Note that customer_id (the primary key for customers) and subscription_id (the primary key for subscriptions) both appear in this.
When the primary key for one table appears in a different table, it is called a foreign key.
So customer_id is a primary key when it appears in customers, but a foreign key when it appears in orders.
In this example, our primary keys all had somewhat descriptive names. Generally, the primary key will just be called id. Foreign keys will have more descriptive names.
Why is this important? The most common types of joins will be joining a foreign key from one table with the primary key from another table. For instance, when we join orders and customers, we join on customer_id, which is a foreign key in orders and the primary key in customers.