Professional Documents
Culture Documents
SCORE
sid sub_id marks teacher
10 1 70 Java Teacher
10 2 75 C++ Teacher
11 1 80 Java Teacher
teacher is a non-prime attribute that is dependent only on sub_id which is part of candidate key
hence there is partial dependency and we need to remove it.
After Normalization
SUBJECT STUDENT
subject_name sid name reg_no
SUBJECT
sub_id sub_name teacher
te key
ization
DENT
branch address
CSE Kerala
IT Gujarat
IT Rajasthan
SCORE
sid sub_id marks
10 1 70
10 2 75
11 1 80
Before Normalization
STUDENT
sid name reg_no branch address
SUBJECT SCORE
sub_id sub_name teacher sid sub_id marks exam_name
In the Score table, we need to store some more information, which is the exam name and maximum marks, so let's add 2 mor
exam_name depends on sub_id because if you take Workshop lab it will be only for ME students, not for CSE students.
Similarly exam_name depends on sub_id also. Because few subjects will have practical component and few doesn't.
Hence exam_name fully depends on primary key {sid,sub_id}
Max_marks just depends on exam_name. if exam is workshop, then max marks is 200. if exam is external, then max marks is 1
Thus, Max_marks(non-prime attribute) depends only on exam_name(non-prime) which depends on Primary key.
Hence there is a transitive dependency and we need to remove it to form 3NF.
SCORE EXAM
Max_marks sid sub_id marks exam_id exam_id
10 1 70 2 1
10 2 75 2 2
11 1 80 1 3
from Score table and put them in an Exam table and use the exam_id wherever required.
on
SUBJECT
sub_name teacher
EXAM
exam_name Max_marks
Workshop 200
External 100
Practicals 50
Before Normalization
STUDENT
sid subject professor
103 C# P.Chash
101 1 1 P.Java
101 2 2 P.Cpp
102 3 3 P.Java2
103 4 4 P.Chash
104 1
Normal Form.
tables, student table and professor table.
FESSOR
subject
Java
C++
Java
C#
Before Normalization After N
To make the above relation satify the 4
COLLEGE_ENROLLMENT TABLE CourseOpted Table
s_id course hobby s_id course
2 C# Cricket 2 C#
As you can see in the table above, student with s_id 1 has opted for two courses, Science and
You must be thinking what problem this can lead to, right?
Well the two records for student with s_id 1, will give rise to two more records, as shown below, because
COLLEGE_ENROLLMENT TABLE
s_id course hobby
1 Science Cricket
1 Science Hockey
1 Maths Cricket
1 Maths Hockey
And, in the table above, there is no relationship between the columns course and hobby. They are indepe
So there is multi-value dependency, which leads to un-necessary repetition of data and other anomalies as
After Normalization
relation satify the 4th normal form, we can decompose the table into 2 tables.
Hobbies Table
s_id hobby
1 Cricket
1 Hockey
2 Cricket
2 Hockey
wn below, because for one student, two hobbies exists, hence along with both the courses, these hobbies should be
f 45thn