Mobile Development

Java & Others

Corporate Training

With DOT NET TRICKS mentors, you can enchance your employees skills as per changing technology landscape. Our coprporate training programs are specially designed for that, so that your employees can develop app with latest technologies.

Campus Training

DOT NET TRICKS is very dedicated to provide high quality training for students. If you would like to conduct a campus training then DOT NET TRICKS is the best choice. Our expert mentors will train your students in your campus.

Industrial/Summar Training

DOT NET TRICKS is very dedicated to provide live project based industrial training to students. Our expert mentors are availabe to provide you six months/six weeks industrial training or one month summar training.

About Us

Hey! I'm Shailendra Chauhan full-time author, consultant & trainer. I have more than 6 years of hand over Microsoft .NET technologies and other web technologies. I am the founder & chief editor of www.dotnet-tricks.com & www.dotnettricks.com.

I like to share my working experience, research and knowledge through my well-known blog.

Advertise with Us

Dot Net Tricks is very dedicated to provide high quality technical content that is completely free world wide. If you would like to advertise your's product to
specific audience like college students, developers, programmers & software professionals
then Dot Net Tricks is the best choice for placing your product's ad.

Normalization or data normalization is a process to organize the data into tabular format (database tables). A good database design includes the normalization, without normalization a database system may slow, inefficient and might not produce the expected result. Normalization reduces the data redundancy and inconsistent data dependency.

Normal Forms

We organize the data into database tables by using normal forms rules or conditions. Normal forms help us to make a good database design. Generally we organize the data up to third normal form. We rarely use the fourth and fifth normal form.

To understand normal forms consider the folowing unnormalized database table. Now we will normalize the data of below table using normal forms.

First Normal Form (1NF)

A database table is said to be in 1NF if it contains no repeating fields/columns. The process of converting the UNF table into 1NF is as follows:

Separate the repeating fields into new database tables along with the key from unnormalized database table.

The primary key of new database tables may be a composite key

1NF of above UNF table is as follows:

Second Normal Form (2NF)

A database table is said to be in 2NF if it is in 1NF and contains only those fields/columns that are functionally dependent(means the value of field is determined by the value of another field(s)) on the primary key. In 2NF we remove the partial dependencies of any non-key field.

The process of converting the database table into 2NF is as follows:

Remove the partial dependencies(A type of functional dependency where a field is only functionally dependent on the part of primary key) of any non-key field.

If field B depends on field A and vice versa. Also for a given value of B, we have only one possible value of A and vice versa, Then we put the field B in to new database table where B will be primary key and also marked as foreign key in parent table.

2NF of above 1NF tables is as follows:

Third Normal Form (3NF)

A database table is said to be in 3NF if it is in 2NF and all non keys fields should be dependent on primary key or We can also said a table to be in 3NF if it is in 2NF and no fields of the table is transitively functionally dependent on the primary key.The process of converting the table into 3NF is as follows:

Remove the transitive dependecies(A type of functional dependency where a field is functionally dependent on the Field that is not the primary key.Hence its value is determined, indirectly by the primary key )

Make separate table for transitive dependent Field.

3NF of above 2NF tables is as follows:

Boyce Code Normal Form (BCNF)

A database table is said to be in BCNF if it is in 3NF and contains each and every determinant as a candidate key.The process of converting the table into BCNF is as follows:

Remove the non trival functional dependency.

Make separate table for the determinants.

BCNF of below table is as follows:

Fourth Normal Form (4NF)

A database table is said to be in 4NF if it is in BCNF and primary key has one-to-one relationship to all non keys fields or We can also said a table to be in 4NF if it is in BCNF and contains no multi-valued dependencies.The process of converting the table into 4NF is as follows:

Remove the multivalued dependency.

Make separate table for multivalued Fields.

4NF of below table is as follows:

Fifth Normal Form (5NF)

A database table is said to be in 5NF if it is in 4NF and contains no redundant values or We can also said a table to be in 5NF if it is in 4NF and contains no join dependencies.The process of converting the table into 5NF is as follows:

Remove the join dependency.

Break the database table into smaller and smaller tables to remove all data redundancy.

5NF of below table is as follows:

Summary

In this article I try to explain the Normalization with example. I hope after reading this article you will be able to understand Normal Forms. I would like to have feedback from my blog readers. Please post your feedback, question, or comments about this article.

This is my personal blog and having articles on .net and others .net related technologies.
The opinions expressed here are my own and not belongs to my employer or other organization.
I have listed my own learning experience on this blog.