Solution to Exercise 1
In this lesson we will discuss the solution to exercise 1.
We'll cover the following
Solution
The second normal form states that it should meet all the rules for 1NF and there must be no partial dependencies between any of the columns with the primary key.
Customer-order table
Cust_Id | Cust_Name | Order_Id | Order_Detail | Order_Category |
---|---|---|---|---|
1 | Jack | 34 | Shampoo | Hygiene |
2 | Bruce | 22 | TV | Electronics |
3 | Amanda | 84 | Shirts | Clothing |
4 | James | 12 | Shoes | Clothing |
2 | Bruce | 62 | Glasses | Clothing |
5 | Veronica | 84 | Shirts | Clothing |
First, we can see that the table above is in the first normal form; it obeys all the rules of the first normal form.
Secondly, the primary key consists of the Cust_Id
and the Order_Id
. Combined, they are unique assuming the same customer would not order the same thing.
However, the table is not in the second normal form because there are partial dependencies of primary keys and columns. Cust_Name
is dependent on Cust_Id
and there’s no real link between a customer’s name and what he/she purchased. The Order_Detail
and Order_Category
are also dependent on the Order_Id
, but they are not dependent on the Cust_Id
, because there is no link between a Cust_Id
and an Order_Detail
or their Order_Category
.
To make this table comply with the second normal form, you need to separate the columns into three tables.
First, create a table to store the customer details as shown below:
Customer table
Cust_Id | Cust_Name |
---|---|
1 | Jack |
2 | Bruce |
3 | Amanda |
4 | James |
5 | Veronica |
The next step is to create a table to store the details of each order:
Orders table
Order_Id | Order_Detail | Order_Category |
---|---|---|
34 | Shampoo | Hygiene |
22 | TV | Electronics |
84 | Shirts | Clothing |
12 | Shoes | Clothing |
62 | Glasses | Clothing |
Finally, create a third table storing just the Cust_Id
and the Order_Id
to keep track of all the orders for a customer:
Customer-order table
Cust_Id | Order_Id |
---|---|
1 | 34 |
2 | 22 |
3 | 84 |
4 | 12 |
2 | 62 |
5 | 84 |
The third table is simply used to link the first two tables.
Now all the tables are in 2NF as there is no partial dependency between any column.
Get hands-on with 1300+ tech skills courses.