ER Model to Relational Database
In the previous cheatsheet, we've learnt to build an ER model for a given scenario. Now, let's convert this ER model to Relational Database. Let's consider the same e-commerce application.
E-commerce Application
In a typical e-commerce application,
- Customer has only one cart. A cart belongs to only one customer
- Customer can add products to cart
- Cart contains multiple products
- Customer can save multiple addresses in the application for further use like selecting delivery address
data:image/s3,"s3://crabby-images/9da2e/9da2ed815f88bbc33794bdbd7b25425bf6d50d17" alt=""
Entity Type to Table
data:image/s3,"s3://crabby-images/88ec6/88ec6ef68ae31ae7e44634856138d483732b016a" alt=""
Primary key: A minimal set of attributes (columns) in a table that uniquely identifies rows in a table.
In the following tables, all the ids are primary keys as they uniquely identify each row in the table.
data:image/s3,"s3://crabby-images/c590b/c590b7b0857bed00e42bf5e16a2d8e685518eae5" alt=""
Relationships
Relation Between Customer and Address - One to Many Relationship
- A customer can have multiple addresses.
- An address is related to only one customer.
We store the primary key of a customer in the address table to denote that the addresses are related to a particular customer. This new column/s in the table that refer to the primary key of another table is called Foreign Key.
data:image/s3,"s3://crabby-images/25eed/25eed225e2a089936f3f50cd7eafeb924ce0f59b" alt=""
data:image/s3,"s3://crabby-images/de7a9/de7a95c5cf58e49aa05e1e73180db342634f5eec" alt=""
Here,
Relation Between Cart and Customer - One to One Relationship
- A customer has only one cart.
- A cart is related to only one customer.
This is similar to one-to-many relationship. But, we need to ensure that only one cart is associated to a customer
data:image/s3,"s3://crabby-images/a700b/a700bd53402af75e01e94fb2d54376705a010399" alt=""
data:image/s3,"s3://crabby-images/de7a9/de7a95c5cf58e49aa05e1e73180db342634f5eec" alt=""
Relation Between Cart and Products - Many to Many Relationship
- A cart can have many products.
- A product can be in many carts.
Here, we cannot store either the primary key of a product in the cart table or vice versa. To store the relationship between the cart and product tables, we use a Junction Table.
data:image/s3,"s3://crabby-images/fd2b1/fd2b18c88cb2694fd3ddc83b08c32ee6ec45eaff" alt=""
E-commerce Usecase: ER Model to Relational Database
Following ER model is represented as the below tables in the relational database.
ER Model
Relational Database
data:image/s3,"s3://crabby-images/de7a9/de7a95c5cf58e49aa05e1e73180db342634f5eec" alt=""
data:image/s3,"s3://crabby-images/5c53e/5c53e2430d9dbd2e474b27cd9f59f6d01c7264c5" alt=""
data:image/s3,"s3://crabby-images/cfcbf/cfcbf456004faad7712c72501e111a368159ebb7" alt=""
data:image/s3,"s3://crabby-images/71b57/71b57493349f6b8183a7bec0cb49d524f737395c" alt=""